24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 361  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0856材料化工调剂 总分330 +11 zhubinhao 2026-03-27 11/550 2026-03-28 20:22 by 418490947
[考研] 332求调剂 +4 蕉蕉123 2026-03-28 4/200 2026-03-28 20:12 by wxiongid
[考研] 本科双非材料,跨考一志愿华电085801电气,283求调剂,任何专业都可以 +5 芝士雪baoo 2026-03-28 6/300 2026-03-28 15:25 by 1018329917
[考研] 一志愿北京工业大学,324分求调剂 +4 零八# 2026-03-28 4/200 2026-03-28 15:01 by 17865157980
[考研] 一志愿厦门大学化学学硕307求调剂 +10 y7czhao 2026-03-26 10/500 2026-03-28 14:23 by 唐沐儿
[考研] 339求调剂,想调回江苏 +6 烤麦芽 2026-03-27 8/400 2026-03-28 10:40 by 烤麦芽
[考研] 274求调剂 +17 顾九笙要谦虚 2026-03-24 23/1150 2026-03-27 15:16 by caszguilin
[考研] 286求调剂 +4 lim0922 2026-03-26 4/200 2026-03-27 10:28 by guoweigw
[考研] 材料学硕333求调剂 +8 北道巷 2026-03-24 8/400 2026-03-27 10:18 by 我是小康
[考研] 336材料求调剂 +7 陈滢莹 2026-03-26 9/450 2026-03-27 00:20 by wxiongid
[考研] 一志愿北化求调剂 +3 Jsman 2026-03-22 3/150 2026-03-26 21:06 by ajpv风雷
[考研] 321求调剂 +6 wasdssaa 2026-03-26 6/300 2026-03-26 20:57 by sanrepian
[考研] 325求调剂 +3 Aoyijiang 2026-03-23 3/150 2026-03-26 20:46 by 不吃魚的貓
[考研] 329求调剂 +5 1() 2026-03-22 5/250 2026-03-26 20:40 by fmesaito
[考研] 化学工程085602 305分求调剂 +17 RichLi_ 2026-03-25 17/850 2026-03-26 19:44 by plmuchong
[考研] 085602化学工程求调剂。 +4 平乐乐乐 2026-03-26 4/200 2026-03-26 17:57 by fmesaito
[考研] 309求调剂 +4 gajsj 2026-03-25 5/250 2026-03-26 00:27 by Dyhoer
[考研] 材料与化工328分调剂 +6 。,。,。,。i 2026-03-23 6/300 2026-03-25 22:30 by 418490947
[考研] 材料调剂 +3 iwinso 2026-03-23 3/150 2026-03-25 11:29 by greychen00
[考研] 上海电力大学材料防护与新材料重点实验室招收调剂研究生(材料、化学、电化学,环境) +4 我爱学电池 2026-03-23 4/200 2026-03-25 00:59 by 1027_324
信息提示
请填处理意见