24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 363  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[硕博家园] 招收生物学/细胞生物学调剂 +4 IceGuo 2026-03-26 5/250 2026-03-29 01:25 by griffith2014
[考研] 085600 材料与化工 329分求调剂 +10 Mr. Z 2026-03-25 10/500 2026-03-29 00:34 by 我是小康
[考研] 356求调剂 +3 gysy?s?a 2026-03-28 3/150 2026-03-29 00:33 by 544594351
[考研] 一志愿郑州大学,080500学硕,总分317分求调剂 +5 举个栗子oi 2026-03-24 6/300 2026-03-28 23:03 by lizhi8172
[考研] 11408软件工程求调剂 +3 Qiu学ing 2026-03-28 3/150 2026-03-28 21:50 by zhq0425
[考研] 生物学学硕,一志愿湖南大学,初试成绩338 +6 YYYYYNNNNN 2026-03-26 7/350 2026-03-28 20:52 by 唐沐儿
[考研] 0703本科郑州大学求调剂 +3 nhj_ 2026-03-25 3/150 2026-03-28 13:24 by Iveryant
[考研] 考研调剂 +4 Sanmu-124 2026-03-26 4/200 2026-03-27 17:49 by kiokin
[考研] 材料求调剂 +5 .m.. 2026-03-25 5/250 2026-03-27 11:08 by 不吃魚的貓
[考研] 343求调剂 +4 赠我一本书 2026-03-23 4/200 2026-03-27 00:40 by wxiongid
[考研] 342求调剂 +3 加油a李zs 2026-03-26 3/150 2026-03-27 00:29 by wxiongid
[考研] 材料与化工304求B区调剂 +3 邱gl 2026-03-26 6/300 2026-03-26 18:03 by 邱gl
[考研] 271求调剂 +6 生如夏花… 2026-03-22 6/300 2026-03-26 16:48 by 张凯十八号
[考研] 352求调剂 +4 大米饭! 2026-03-22 4/200 2026-03-26 16:40 by 不吃魚的貓
[考研] 材料科学与工程 317求调剂 +4 JKSOIID 2026-03-26 4/200 2026-03-26 15:58 by 不吃魚的貓
[考研] 机械学硕总分317求调剂!!!! +4 Acaciad 2026-03-25 4/200 2026-03-25 19:59 by hanserlol
[考研] 【2026考研调剂】制药工程 284分 求相关专业调剂名额 +4 袁奂奂 2026-03-25 8/400 2026-03-25 14:32 by lbsjt
[考研] 289材料与化工(085600)B区求调剂 +4 这么名字咋样 2026-03-22 5/250 2026-03-25 08:20 by mx.yue
[考研] 上海电力大学材料防护与新材料重点实验室招收调剂研究生(材料、化学、电化学,环境) +4 我爱学电池 2026-03-23 4/200 2026-03-25 00:59 by 1027_324
[考研] 接收2026硕士调剂(学硕+专硕) +4 allen-yin 2026-03-23 6/300 2026-03-23 15:04 by 汪!?!
信息提示
请填处理意见