首页 VB常用算法6 排序

VB常用算法6 排序

举报
开通vip

VB常用算法6 排序VB常用算法6 排序 VB常用算法----排序 1、选择法排序 (1) 利用循环从n个数中选出最小数的下标,结束循环后,将最小数与第一 个数交换位置; (2) 除第一个数外,在剩下的n-1个数中再按方法(1)选出次小的数,与第二 个数交换位置; (3) 以此类推,最后构成递增序列。 譬如: 8 6 9 3 2 7 第一轮交换后 2 6 9 3 8 7 第二轮交换后 2 3 9 6 8 7 第三轮交换后 2 3 6 9 8 7 第四轮交换后 2 3 6 7 8 9 第五轮无交换 2 3 6 7...

VB常用算法6 排序
VB常用算法6 排序 VB常用算法----排序 1、选择法排序 (1) 利用循环从n个数中选出最小数的下标,结束循环后,将最小数与第一 个数交换位置; (2) 除第一个数外,在剩下的n-1个数中再按方法(1)选出次小的数,与第二 个数交换位置; (3) 以此类推,最后构成递增序列。 譬如: 8 6 9 3 2 7 第一轮交换后 2 6 9 3 8 7 第二轮交换后 2 3 9 6 8 7 第三轮交换后 2 3 6 9 8 7 第四轮交换后 2 3 6 7 8 9 第五轮无交换 2 3 6 7 8 9 程序代码如下: Private Sub xzPaiXu(a() As Double, sheng As Boolean) 'a为需要排序的数组,sheng为True则为升序排列,为False,则为降序排列。 Dim i As Integer, j As Integer Dim temp As Double Dim m As Integer For i = LBound(a) To UBound(a) - 1 '进行数组大小-1轮比较 m = i '在第i轮比较时,假定第 'i个元素为最值元素 For j = i + 1 To UBound(a) '在剩下的元素中找出最 '值元素的下标并记录在m中 If sheng Then '若为升序,则m记录最小元素 '下标,否则记录最大元素下标 If a(j) < a(m) Then m = j Else If a(j) > a(m) Then m = j End If Next j '将最值元素与第i个元素交换 temp = a(i) a(i) = a(m) 1 a(m) = temp Next i End Sub 调用该过程示例: Option Base 1 Private Sub Command1_Click() Dim b(6) As Double b(1) = 8 b(2) = 6 b(3) = 9 b(4) = 3 b(5) = 2 b(6) = 7 Call xzPaiXu(b, True) For i% = 1 To 6 Print b(i) Next End Sub 2、冒泡法排序 选择排序法在每一轮排序时寻找最值元素的下标,出了内循环(一轮排序结 束时,确定最值下标),再交换最小数的位置;而冒泡法在每一轮排序时将相邻 的数比较,当次序不对时就立即交换位置,出了内循环,最值数已经冒出。 (((( 譬如: 8 6 9 3 2 7 第一8 6 9 3 2 7 轮比 8 6 9 2 3 7 较结 8 6 2 9 3 7 束后, 最值8 2 6 9 3 7 冒出 2 8 6 9 3 7 …. 2 3 8 6 9 7 第二轮次最值冒出 …. 第三轮排序后 2 3 6 8 7 9 2 …. 第四轮排序后 2 3 6 7 8 9 …. 2 3 6 7 8 9 第五轮排序后 程序代码如下: Private Sub mpPaiXu(a() As Double, sheng As Boolean) 'a为需要排序的数组,sheng为True则为升序排列,为False,则为降序排列。 Dim i As Integer, j As Integer Dim temp As Double Dim m As Integer For i = LBound(a) To UBound(a) - 1 '进行n-1轮比较 For j = UBound(a) To i + 1 Step -1 '从n到i个元素两两进行比较 '循环变量j终值为I+1,是因为比较过程中元素下标用到j-1 If sheng Then '若次序不对,马上进行交换 If a(j) < a(j - 1) Then temp = a(j) a(j) = a(j - 1) a(j - 1) = temp End If Else If a(j) > a(j - 1) Then temp = a(j) a(j) = a(j - 1) a(j - 1) = temp End If End If '出了内循环,一轮排序结束 Next j '最值元素冒到最上边 Next i End Sub 调用该过程代码与前面的选择法排序相同。 3 3、实战练习 1) 完善程序填空(2003秋二(10)) 下面是一个采用拉锯式排序法对数组元素按升序进行排序的程序,所谓“拉(((((( 锯式排序法”是前一遍把最小的元素从下到上送到最上的位置,后一遍则是从上((((( 到下把最大的元素送到最下的位置。 Option Base 1 Private Sub Command1_Click() Dim a(10) As Integer,i As Integer For i = 1 To 10 a(i) = Int(Rnd * 10)+1 Text1 = Text1 & Str(a(i)) Next i Call shaker_sort(a) For i = 1 To 10 Text2 = Text2 & Str(a(i)) Next i End Sub Private Sub Shaker_sort(k() As Integer) Dim i As Integer, c As Integer, d As Integer Dim t As Integer c = 1 d = ( 1 ) Do For ( 2 ) Step -1 If k(i - 1) > k(i) Then t = k(i - 1): k(i - 1) = k(i): k(i) = t End If Next i ( 3 ) For i = c + 1 To d If ( 4 ) Then t = k(i - 1): k(i - 1) = k(i): k(i) = t End If Next i d = d - 1 Loop While ( 5 ) End Sub 4 2) 编程题(2002秋上机试卷04) 把文本框输入的字符串按降序添加到列 关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf 框中。 5
本文档为【VB常用算法6 排序】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_036899
暂无简介~
格式:doc
大小:35KB
软件:Word
页数:0
分类:生活休闲
上传时间:2017-10-17
浏览量:25