VB选择法排序

以下代码是用选择法为随机产生的10个数字排序:
Private Sub Command1_Click()
Dim a(1 To 10) As Integer
For i = 1 To 10
a(i) = Int(Rnd * 10)
Print a(i);
Next i
Print

For i = 1 To 9
For j = i + 1 To 10
If a(i) > a(j) Then
t = a(i): a(i) = a(j): a(j) = t
End If
Next j
Print a(i);
Next i
Print a(i);

End Sub

书中写的是:(1)从n个数中选出最小数的下标,出了循环,将最小数与第一个数交换位置;
(2)除第一个数外,在剩下的n-1个数中再按方法(1)选出次小的数,与第二个数交换位置;
(3)以此类推,最后构成递增序列。

请问这个过程中到底哪一步怎样实现的从n个数中选出最小数,有点不太明白,请帮忙解释下,谢谢!
举个例子麻烦大家解释下:
例如 5 3 2 7这四个数进行降序排列,那么两者比较如果后者小于前者则交换位置
一共进行三轮排序,第一轮中,首先3<5,二者交换位置,变成3 5 2 7,之后3和2相比,再交换位置,最后变成2537,这样思考正确吗?谢谢!还有为什么书上只说将最小数与第一个数交换位置,那样第一轮结束后不就应该是2 3 5 7了吗?

Private Sub Command1_Click()

Dim a(1 To 10) As Integer

For i = 1 To 10

a(i) = Int(Rnd * 10)

Print a(i);

Next i

Print

'以上十随机得出10个数

For i = 1 To 9 '这里开始是双重循环

For j = i + 1 To 10

If a(i) > a(j) Then '如果前一个数大于后一个数则交换位置

t = a(i): a(i) = a(j): a(j) = t

End If

Next j

Print a(i);

Next i

Print a(i);

End Sub

I等于1时 就是拿第一位和第二位比较 比较大的的数排后面 然后比较第一位和第三位 For j = i + 1 

To 10 直到比较到最后一位

i=2 时也是如此 循环9次就完成排序

5 3 2 7

i=1 时

J=2时 3 5 2 7

J=3时 2 5 3 7

j=4时 2 5 3 7

I=2时

j=3时 2 3 5 7


扩展资料

Private Sub Command1_Click()

Dim a(10) As Integer

Dim b As Integer

Dim i As Integer

Dim j As Integer

Dim k As Integer

For i = 1 To 10

a(i) = Int(Rnd * 90 + 10)

Print a(i);

Next i

Print

For i = 1 To 9

k = i

For j = k + 1 To 10

If a(j) < a(k) Then k = j

Next j

If a(i) > a(k) Then

b = a(i)

a(i) = a(k)

a(k) = b

End If

Next i

For i = 1 To 10

Print a(i);

Next i

Print

End Sub

参考资料:百度百科 - 选择法排序

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-10-04
Private Sub Command1_Click()
Dim a(1 To 10) As Integer
For i = 1 To 10
a(i) = Int(Rnd * 10)
Print a(i);
Next i
Print
'以上十随机得出10个数
For i = 1 To 9 '这里开始是双重循环
For j = i + 1 To 10
If a(i) > a(j) Then '如果前一个数大于后一个数则交换位置
t = a(i): a(i) = a(j): a(j) = t
End If
Next j
Print a(i);
Next i
Print a(i);

End Sub

I等于1时 就是拿第一位和第二位比较 比较大的的数排后面 然后比较第一位和第三位 For j = i + 1 To 10 直到比较到最后一位
i=2 时也是如此 循环9次就完成排序

5 3 2 7
i=1 时
J=2时 3 5 2 7
J=3时 2 5 3 7
j=4时 2 5 3 7
I=2时
j=3时 2 3 5 7本回答被提问者采纳
第2个回答  2013-04-02
假如对 5 3 2 7这四个数进行降序排列,总共需要3轮比较 即外循环的循环次数
第1轮比较:5与3比 不交换 ;5与2比 不交换; 5与7比 交换;数组变成 7 3 2 5
第2轮比较:3与2比 不交换; 3与5比 交换; 数组变成 7 5 3 2
第3轮比较:3与2比 不交换; 数组变成 7 5 3 2
第3个回答  2009-07-02
这叫冒泡算法
你自己按F8调试,用鼠标定位变量,查看每个变量的变化,比别人说更容易理解...