| 查看: 722 | 回复: 3 | |||
[求助]
用vb证明一个数组可以经过换行和换列的方法等于另一个数组 已有1人参与
|
|
用vb证明一个数组可以经过换行和换列的方法等于另一个数组,如下文,vb运行就卡住了,是运算方法太复杂了,还是我写的程序有错?求你一个能解决问题的方法 Dim zj(11, 12) As Integer For i = 0 To 11 For j = 0 To 12 zj(i, j) = 0 Next Next zj(1, 1) = 1 zj(1, 2) = 1 zj(1, 3) = 1 zj(1, 4) = 1 zj(1, 5) = 1 zj(1, 6) = 1 zj(1, 7) = 2 zj(1, 8) = 2 zj(1, 9) = 2 zj(1, 10) = 2 zj(1, 11) = 2 zj(1, 12) = 2 zj(2, 1) = 1 zj(2, 2) = 1 zj(2, 3) = 1 zj(2, 4) = 2 zj(2, 5) = 2 zj(2, 6) = 2 zj(2, 7) = 1 zj(2, 8) = 1 zj(2, 9) = 1 zj(2, 10) = 2 zj(2, 11) = 2 zj(2, 12) = 2 zj(3, 1) = 1 zj(3, 2) = 1 zj(3, 3) = 2 zj(3, 4) = 1 zj(3, 5) = 2 zj(3, 6) = 2 zj(3, 7) = 2 zj(3, 8) = 2 zj(3, 9) = 1 zj(3, 10) = 2 zj(3, 11) = 1 zj(3, 12) = 1 zj(4, 1) = 1 zj(4, 2) = 1 zj(4, 3) = 2 zj(4, 4) = 2 zj(4, 5) = 1 zj(4, 6) = 2 zj(4, 7) = 2 zj(4, 8) = 1 zj(4, 9) = 2 zj(4, 10) = 1 zj(4, 11) = 2 zj(4, 12) = 1 zj(5, 1) = 1 zj(5, 2) = 1 zj(5, 3) = 2 zj(5, 4) = 2 zj(5, 5) = 2 zj(5, 6) = 1 zj(5, 7) = 1 zj(5, 8) = 2 zj(5, 9) = 2 zj(5, 10) = 1 zj(5, 11) = 1 zj(5, 12) = 2 zj(6, 1) = 1 zj(6, 2) = 2 zj(6, 3) = 1 zj(6, 4) = 1 zj(6, 5) = 2 zj(6, 6) = 2 zj(6, 7) = 1 zj(6, 8) = 2 zj(6, 9) = 2 zj(6, 10) = 1 zj(6, 11) = 2 zj(6, 12) = 1 zj(7, 1) = 1 zj(7, 2) = 2 zj(7, 3) = 1 zj(7, 4) = 2 zj(7, 5) = 1 zj(7, 6) = 2 zj(7, 7) = 2 zj(7, 8) = 2 zj(7, 9) = 1 zj(7, 10) = 1 zj(7, 11) = 1 zj(7, 12) = 2 zj(8, 1) = 1 zj(8, 2) = 2 zj(8, 3) = 1 zj(8, 4) = 2 zj(8, 5) = 2 zj(8, 6) = 1 zj(8, 7) = 2 zj(8, 8) = 1 zj(8, 9) = 2 zj(8, 10) = 2 zj(8, 11) = 1 zj(8, 12) = 1 zj(9, 1) = 1 zj(9, 2) = 2 zj(9, 3) = 2 zj(9, 4) = 1 zj(9, 5) = 1 zj(9, 6) = 2 zj(9, 7) = 1 zj(9, 8) = 1 zj(9, 9) = 2 zj(9, 10) = 2 zj(9, 11) = 1 zj(9, 12) = 2 zj(10, 1) = 1 zj(10, 2) = 2 zj(10, 3) = 2 zj(10, 4) = 1 zj(10, 5) = 2 zj(10, 6) = 1 zj(10, 7) = 2 zj(10, 8) = 1 zj(10, 9) = 1 zj(10, 10) = 1 zj(10, 11) = 2 zj(10, 12) = 2 zj(11, 1) = 1 zj(11, 2) = 2 zj(11, 3) = 2 zj(11, 4) = 2 zj(11, 5) = 1 zj(11, 6) = 1 zj(11, 7) = 1 zj(11, 8) = 2 zj(11, 9) = 1 zj(11, 10) = 2 zj(11, 11) = 2 zj(11, 12) = 1 Dim pb(11, 12) As Integer For i = 0 To 11 For j = 0 To 12 pb(i, j) = 0 Next Next pb(1, 1) = 2 pb(1, 2) = 2 pb(1, 3) = 1 pb(1, 4) = 2 pb(1, 5) = 2 pb(1, 6) = 2 pb(1, 7) = 1 pb(1, 8) = 1 pb(1, 9) = 1 pb(1, 10) = 2 pb(1, 11) = 1 pb(1, 12) = 1 pb(2, 1) = 1 pb(2, 2) = 2 pb(2, 3) = 2 pb(2, 4) = 1 pb(2, 5) = 2 pb(2, 6) = 2 pb(2, 7) = 2 pb(2, 8) = 1 pb(2, 9) = 1 pb(2, 10) = 1 pb(2, 11) = 2 pb(2, 12) = 1 pb(3, 1) = 2 pb(3, 2) = 1 pb(3, 3) = 2 pb(3, 4) = 2 pb(3, 5) = 1 pb(3, 6) = 2 pb(3, 7) = 2 pb(3, 8) = 2 pb(3, 9) = 1 pb(3, 10) = 1 pb(3, 11) = 1 pb(3, 12) = 1 pb(4, 1) = 1 pb(4, 2) = 2 pb(4, 3) = 1 pb(4, 4) = 2 pb(4, 5) = 2 pb(4, 6) = 1 pb(4, 7) = 2 pb(4, 8) = 2 pb(4, 9) = 2 pb(4, 10) = 1 pb(4, 11) = 1 pb(4, 12) = 1 pb(5, 1) = 1 pb(5, 2) = 1 pb(5, 3) = 2 pb(5, 4) = 1 pb(5, 5) = 2 pb(5, 6) = 2 pb(5, 7) = 1 pb(5, 8) = 2 pb(5, 9) = 2 pb(5, 10) = 2 pb(5, 11) = 1 pb(5, 12) = 1 pb(6, 1) = 1 pb(6, 2) = 1 pb(6, 3) = 1 pb(6, 4) = 2 pb(6, 5) = 1 pb(6, 6) = 2 pb(6, 7) = 2 pb(6, 8) = 1 pb(6, 9) = 2 pb(6, 10) = 2 pb(6, 11) = 2 pb(6, 12) = 1 pb(7, 1) = 2 pb(7, 2) = 1 pb(7, 3) = 1 pb(7, 4) = 1 pb(7, 5) = 2 pb(7, 6) = 1 pb(7, 7) = 2 pb(7, 8) = 2 pb(7, 9) = 1 pb(7, 10) = 2 pb(7, 11) = 2 pb(7, 12) = 1 pb(8, 1) = 2 pb(8, 2) = 2 pb(8, 3) = 1 pb(8, 4) = 1 pb(8, 5) = 1 pb(8, 6) = 2 pb(8, 7) = 1 pb(8, 8) = 2 pb(8, 9) = 2 pb(8, 10) = 1 pb(8, 11) = 2 pb(8, 12) = 1 pb(9, 1) = 2 pb(9, 2) = 2 pb(9, 3) = 2 pb(9, 4) = 1 pb(9, 5) = 1 pb(9, 6) = 1 pb(9, 7) = 2 pb(9, 8) = 1 pb(9, 9) = 2 pb(9, 10) = 2 pb(9, 11) = 1 pb(9, 12) = 1 pb(10, 1) = 1 pb(10, 2) = 2 pb(10, 3) = 2 pb(10, 4) = 2 pb(10, 5) = 1 pb(10, 6) = 1 pb(10, 7) = 1 pb(10, 8) = 2 pb(10, 9) = 1 pb(10, 10) = 2 pb(10, 11) = 2 pb(10, 12) = 1 pb(11, 1) = 2 pb(11, 2) = 1 pb(11, 3) = 2 pb(11, 4) = 2 pb(11, 5) = 2 pb(11, 6) = 1 pb(11, 7) = 1 pb(11, 8) = 1 pb(11, 9) = 2 pb(11, 10) = 1 pb(11, 11) = 2 pb(11, 12) = 1 Dim hl(11, 12), hh(11, 12) '定义过程数组:换行和换列,分别采用循环穷举所有可能的排列,在每一个换列的数组穷举换行的所有结果 For i = 0 To 11 For j = 0 To 12 hl(i, j) = 0 hh(i, j) = 0 Next Next For i1 = 1 To 11 For i2 = 1 To 11 For i3 = 1 To 11 For i4 = 1 To 11 For i5 = 1 To 11 For i6 = 1 To 11 For i7 = 1 To 11 For i8 = 1 To 11 For i9 = 1 To 11 For i10 = 1 To 11 For i11 = 1 To 11 For j1 = 1 To 11 For j2 = 1 To 12 If j1 = 1 Then hl(j1, j2) = pb(i1, j2) If j1 = 2 Then hl(j1, j2) = pb(i2, j2) If j1 = 3 Then hl(j1, j2) = pb(i3, j2) If j1 = 4 Then hl(j1, j2) = pb(i4, j2) If j1 = 5 Then hl(j1, j2) = pb(i5, j2) If j1 = 6 Then hl(j1, j2) = pb(i6, j2) If j1 = 7 Then hl(j1, j2) = pb(i7, j2) If j1 = 8 Then hl(j1, j2) = pb(i8, j2) If j1 = 9 Then hl(j1, j2) = pb(i9, j2) If j1 = 10 Then hl(j1, j2) = pb(i10, j2) If j1 = 11 Then hl(j1, j2) = pb(i11, j2) Next Next For k1 = 1 To 12 For k2 = 1 To 12 For k3 = 1 To 12 For k4 = 1 To 12 For k5 = 1 To 12 For k6 = 1 To 12 For k7 = 1 To 12 For k8 = 1 To 12 For k9 = 1 To 12 For k10 = 1 To 12 For k11 = 1 To 12 For k12 = 1 To 12 For l2 = 1 To 12 For l1 = 1 To 11 If l2 = 1 Then hh(l1, l2) = hl(l1, k1) If l2 = 2 Then hh(l1, l2) = hl(l1, k2) If l2 = 3 Then hh(l1, l2) = hl(l1, k3) If l2 = 4 Then hh(l1, l2) = hl(l1, k4) If l2 = 5 Then hh(l1, l2) = hl(l1, k5) If l2 = 6 Then hh(l1, l2) = hl(l1, k6) If l2 = 7 Then hh(l1, l2) = hl(l1, k7) If l2 = 8 Then hh(l1, l2) = hl(l1, k8) If l2 = 9 Then hh(l1, l2) = hl(l1, k9) If l2 = 10 Then hh(l1, l2) = hl(l1, k10) If l2 = 11 Then hh(l1, l2) = hl(l1, k11) If l2 = 12 Then hh(l1, l2) = hl(l1, k12) Next Next Dim test2 = 0 For x = 1 To 11 For y = 1 To 12 If hl(x, y) = zj(x, y) Then test2 = test2 + 1 End If Next Next If test2 = 11 * 12 Then TextBox1.Text = "成功"+ TextBox1.Text End If Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next Next |
» 猜你喜欢
实验室接单子
已经有3人回复
要不要辞职读博?
已经有5人回复
不自信的我
已经有10人回复
磺酰氟产物,毕不了业了!
已经有8人回复
求助:我三月中下旬出站,青基依托单位怎么办?
已经有10人回复
26申博(荧光探针方向,有机合成)
已经有4人回复
论文终于录用啦!满足毕业条件了
已经有26人回复
2026年机械制造与材料应用国际会议 (ICMMMA 2026)
已经有4人回复
Cas 72-43-5需要30g,定制合成,能接单的留言
已经有8人回复
北京211副教授,35岁,想重新出发,去国外做博后,怎么样?
已经有8人回复
» 本主题相关价值贴推荐,对您同样有帮助:
请问VB如何实现顺序读取文本文件中的数据,并将读取到的数据保存在二维数组呢
已经有6人回复
复数数组的傅里叶变换,求一个fortran的例子
已经有18人回复
在VB 中怎样只给一维数组的第一个元素赋值?
已经有5人回复
如何将一个向量赋值给三维数组中的一部分
已经有7人回复
ANSYS中对一组体的选择集,怎么用ADPL命令流获取这组体的编号到一个数组里啊?
已经有3人回复
fortran 数组输出
已经有3人回复
C++中,如何将二维数组读到一维中,并且是按列读取。(有程序望修改)(注意不是按行)
已经有12人回复
关于perl 数组的一个小问题。
已经有4人回复
fortran数组输出,行与列请教
已经有7人回复
VC++中函数返回数组指针或者带指针的结构体的编译方式是否可取?
已经有6人回复
VB控件数组的使用
已经有4人回复
怎样将for循环的结果存入数组
已经有6人回复
请教一个应用read时出现数组越界的问题,谢谢
已经有7人回复
请教Fortran下如何给二维或三维数组赋初值,谢谢
已经有3人回复
怎么把从键盘输入的多个字符串分别赋值给字符串数组的一个个元素?
已经有6人回复
三维数组换行输入到文件(intel fortran 编译器)
已经有6人回复
【求助】fortran中是如何实现将两个变量的值在同一行进行打印出来的
已经有7人回复
【求助】从文件读入数组遇到困难
已经有3人回复
【求助】如何提取TXT中某列的数据存入一个数组,再对数组做处理
已经有4人回复
【求助】如何做三维数组的图形
已经有6人回复

deephill
铁杆木虫 (职业作家)
- 应助: 59 (初中生)
- 金币: 5262.3
- 散金: 100
- 红花: 16
- 帖子: 4425
- 在线: 425小时
- 虫号: 305318
- 注册: 2006-12-09
- 性别: GG
- 专业: 微量元素地球化学
【答案】应助回帖
★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ...
感谢参与,应助指数 +1
Micah1011: 金币+200, ★★★★★最佳答案, 感谢回答,请问我用visual stidio2013能让他多线程吗?需要如何配置 2015-03-21 22:17:27
感谢参与,应助指数 +1
Micah1011: 金币+200, ★★★★★最佳答案, 感谢回答,请问我用visual stidio2013能让他多线程吗?需要如何配置 2015-03-21 22:17:27
|
你这个程序一定会卡住的,循环套循环,层数多了,就卡住。 1 要是你怕程序不正确,需要调试。在程序的关键位置 加上stop ,暂停时就会输出结果,可以检查结果,这样不用等到程序运行完就强制结束程序。 2 vb的程序老版本不能开多线程,运算速度不会快。只能等,让程序算,看似停止响应,但程序在计算着了,时间到了,自然出结果。我估计你这个程序可能要等20分钟。 3 有人为了不让程序假死,可以加上sleep(1) 语句。 |
2楼2015-03-21 13:16:23

3楼2015-03-21 22:18:06
deephill
铁杆木虫 (职业作家)
- 应助: 59 (初中生)
- 金币: 5262.3
- 散金: 100
- 红花: 16
- 帖子: 4425
- 在线: 425小时
- 虫号: 305318
- 注册: 2006-12-09
- 性别: GG
- 专业: 微量元素地球化学
4楼2015-03-21 23:43:50












回复此楼