24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 359  |  回复: 1

mkluowen

铜虫 (小有名气)

[求助] 求高手修正

新手,这段程序运行后没设想中的结果,求哪位高手给修改一下。十万火急

Private Sub Form_Click()
Dim ix%, iy%, iz%, nx%, ny%, nz%, N01x#, N01y#, N01z#, C0x1#, C0y1#, C01z#
Dim baindex01, baindex02, natome, namol, index0, index1 As Integer
    baindex01 = 1
    baindex02 = 2
    natom = 0
    namol = 0
    index0 = 1
    index1 = 2
    nd01 = 0
    nb01 = 0
    na01 = 0
    natom = 0
    nmole = 0
    N01x = 0
    N01y = 0
    N01z = 0
    C01x = 0.8773
    C01y = -0.5773
    C01x = 0.6773
Dim boxx, boxy, boxz As Double
    boxx = 4.91
    boxy = 4.91
    boxz = 4.91
    Open "E:\NaCl.dat" For Output As 1
Dim Na01x(), Na01y(), Na01z(), Cl01x(), Cl01y(), Cl01z() As Double
nx = Val(InputBox("输入nx", "nx must be integer and 0<nx<100", "1"  ))
ny = Val(InputBox("输入ny", "ny must be integer and 0<ny<100", "1" ))
nz = Val(InputBox("输入nz", "nz must be integer and 0<nz<100", "1" ))

ReDim Na01x(nx), Na01y(ny), Na01z(nz), Cl01x(nx), Cl01y(ny), Cl01z(nz)
    For ix = 1 To nx
    For iy = 1 To ny
    For iz = 1 To nz
    Na01x(ix) = N01x + (ix - 1) * boxx
    Na01y(iy) = N01y + (iy - 1) * boxy
    Na01z(iz) = N01z + (iz - 1) * boxz
    Cl01x(ix) = C01x + (ix - 1) * boxx
    Cl01y(iy) = C01y + (iy - 1) * boxy
    Cl01z(iz) = C01z + (iz - 1) * boxz
    Write #1, natom, namol + 1, "1", Na01x(ix), Na01y(iy), Na01z(iz)
    Write #1, natom, namol + 1, "2", Cl01x(ix), Cl01y(iy), Cl01z(iz)
    Next iz
    Next iy
    Next ix
    Close #1
   
    End Sub

[ Last edited by mkluowen on 2013-5-5 at 10:11 ]
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ausir

木虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★
mkluowen: 金币+5, ★★★很有帮助 2013-05-16 15:48:50
不是很清楚你想计算出怎样的结果。 但是这段程序的语法上并没有错什么。可以稍作更改的是变量定义语句,就是把所有的变量都必须声明,而不是只定义一行中的最后一个。这个采用Dim 是使用%,#或Integer, Double等没有区别。

Private Sub UserForm_Click()
Dim ix%, iy%, iz%, nx%, ny%, nz%, N01x#, N01y#, N01z#, C0x1#, C0y1#, C01z#
Dim baindex01 As Integer, baindex02 As Integer, natome As Integer, namol As Integer, index0 As Integer, index1 As Integer
Dim boxx#, boxy#, boxz As Double
Dim Na01x#(), Na01y#(), Na01z#(), Cl01x#(), Cl01y#(), Cl01z() As Double
   
baindex01 = 1
baindex02 = 2
natom = 0
namol = 0
index0 = 1
index1 = 2
   
nd01 = 0
nb01 = 0
na01 = 0
natom = 0
nmole = 0
   
N01x = 0
N01y = 0
N01z = 0

C01x = 0.8773
C01y = -0.5773
C01x = 0.6773
   
boxx = 4.91
boxy = 4.91
boxz = 4.91

Open "E:\NaCl.dat" For Output As 1
   
nx = Val(InputBox("输入nx", "nx must be integer and 0<nx<100", "1")
ny = Val(InputBox("输入ny", "ny must be integer and 0<ny<100", "1")
nz = Val(InputBox("输入nz", "nz must be integer and 0<nz<100", "1")

ReDim Na01x(nx), Na01y(ny), Na01z(nz), Cl01x(nx), Cl01y(ny), Cl01z(nz)
   
For ix = 1 To nx
    For iy = 1 To ny
        For iz = 1 To nz
            Na01x(ix) = N01x + (ix - 1) * boxx
            Na01y(iy) = N01y + (iy - 1) * boxy
            Na01z(iz) = N01z + (iz - 1) * boxz
            Cl01x(ix) = C01x + (ix - 1) * boxx
            Cl01y(iy) = C01y + (iy - 1) * boxy
            Cl01z(iz) = C01z + (iz - 1) * boxz
            
            Write #1, natom, namol + 1, "1", Na01x(ix), Na01y(iy), Na01z(iz)
            Write #1, natom, namol + 1, "2", Cl01x(ix), Cl01y(iy), Cl01z(iz)
        Next iz
    Next iy
Next ix

Close #1

MsgBox "Done"
   
End Sub

这个好像是计算了一个立方体的顶点坐标和平移后的坐标。
2楼2013-05-14 13:13:22
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 mkluowen 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0703本科郑州大学求调剂 +3 nhj_ 2026-03-25 3/150 2026-03-28 13:24 by Iveryant
[考研] 315分求调剂 +7 26考研上岸版26 2026-03-26 7/350 2026-03-28 04:05 by fmesaito
[考研] 266求调剂 +11 阳阳哇塞 2026-03-27 12/600 2026-03-27 17:56 by yu221
[考研] 安徽大学专硕生物与医药专业(086000)324分,英语已过四六级,六级521,求调剂 +4 美味可乐鸡翅 2026-03-26 4/200 2026-03-27 15:27 by 星空星月
[考研] 考研化学308分求调剂 +10 你好明天你好 2026-03-23 12/600 2026-03-27 14:43 by shangxh
[考研] 一志愿华东理工大学081700,初试分数271 +6 kotoko_ik 2026-03-23 7/350 2026-03-27 12:29 by 惠州彭于晏
[考研] 085601 材料工程 313分 求调剂 +5 Ong3 2026-03-27 5/250 2026-03-27 12:24 by goldfish51
[考研] 求调剂 +3 刘柯@ 2026-03-24 4/200 2026-03-27 11:28 by shangxh
[考研] 考研调剂 +6 来好运来来来 2026-03-21 7/350 2026-03-25 22:43 by 418490947
[考研] 材料与化工328分调剂 +6 。,。,。,。i 2026-03-23 6/300 2026-03-25 22:30 by 418490947
[考研] 290分调剂求助 +3 吉祥止止陈 2026-03-25 3/150 2026-03-25 19:58 by barlinike
[考研] 0854电子信息求调剂 324 +4 Promise-jyl 2026-03-23 4/200 2026-03-25 11:36 by Sugarlight
[考研] 318求调剂 +5 plum李子 2026-03-21 8/400 2026-03-25 09:26 by aa331100
[考研] 一志愿北化315 求调剂 +3 akrrain 2026-03-24 3/150 2026-03-24 19:35 by 了了了了。。
[考研] 材料专硕找调剂 +5 哈哈哈吼吼吼哈 2026-03-23 5/250 2026-03-24 19:07 by 了了了了。。
[考研] 300求调剂,材料科学英一数二 +5 leaflight 2026-03-24 5/250 2026-03-24 16:25 by laoshidan
[考研] 一志愿河北工业大学0817化工278分求调剂 +7 jhybd 2026-03-23 12/600 2026-03-24 09:03 by jhybd
[考研] 环境学硕288求调剂 +8 皮皮皮123456 2026-03-22 8/400 2026-03-23 23:47 by 热情沙漠
[考研] 接收2026硕士调剂(学硕+专硕) +4 allen-yin 2026-03-23 6/300 2026-03-23 15:04 by 汪!?!
[考研] 一志愿东华大学化学070300,求调剂 +7 2117205181 2026-03-21 8/400 2026-03-22 22:55 by chixmc
信息提示
请填处理意见