欢迎来到天天文库
浏览记录
ID:31693954
大小:56.19 KB
页数:4页
时间:2019-01-17
《vb程序设计中的冒泡排序教学》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、VB程序设计中的冒泡排序教学张远骏(浙江省浦江县第二中学浦江322200)【摘要】:自2015年高一新生开始,浙江省实行新高考改革,信息技术中的排序算法也成为必考考点之一。木文通过对冒泡排序的教学,在学生理解冒泡排序设计思想的基础上,提出了两种新的冒泡排序方法。一是根据可以同时选择出最大数和最小数的特点上提出了双向冒泡法,二是加入了标志位的新的冒泡排序法,以达到培养学生分析问题、发现规律的能力。经过算法分析得出,改进的算法时间复杂度也比传统冒泡排序方法有所改善。【关键字】:排序算法,冒泡排序,双向冒泡排序,标志位冒泡排序,时间复杂度浙江的新高考改革将信息
2、技术课作为技术科目的一部分纳入了高考选考科目中,原木是选修课内容的排序算法及程序实现也成为高考的加试考点。而冒泡排序也是计算机程序设计中的一种重要操作,特别是高效率的排序是计算机研究中的重要课题之一。一、冒泡排序的基木思想冒泡排序是排序中一种简单的排序方法。它的基木思想是对所有相邻记录关键字值进行比较,使较小的(大)关键字的记录值往上升,这样从上到下执行一遍后,关键字最大(小)的记录沉到最底下。在下一遍扫描是,可以不考虑这个关键字最大(小)的记录,而减少一次比较,上述比较过程反复执行,直到所有的记录不再上升为止。冒泡排序算法的实现需要两重循环,我在教学中
3、使用了5张扑克牌来演示冒泡排序的逐个过程(从小到大排序),以强化学牛对冒泡排序的理解。5张扑克牌,要进行从小到大的排序。1、第一轮冒泡排序首先比较第5个数与第4个数,将其中较小的数换到第4个数的位置,然后比较第4个数与第3个数,将其中较小的数换到第3个数的位置,重复这一过程,直到比较完第2个数与第1个数且完成交换,称为第1遍加工。第1遍加工完成后,最小的数据已经上升到第1个位置。2、对余下的第2张到第5张扑克牌重复上述处理过程,直至最后进行余下的两个数据进行比较和交换。具体的排序算法如下:Fori=lto4Forj=5toi+1stepIfa(j)&l切
4、(卜1)thent=a(j):a(j)=a(j-l):a(j-l)=tEndifNextjNexti二、冒泡排序改进方法之一从上述的分析算法我们可以发现,刚才使用的冒泡排序是从一端开始比较的,经过第1轮的排序后使得最小的数上浮到第1个位置,如此重复使得排序完成。那我们可以考虑,在上浮的同时也下沉。在每一趟比较中,最小数上浮,同时使得最大数下沉,这样就可以减少比较的次数,反复执行这一过程直到为1或0时为止,这就是双向冒泡排序的思想。具体的双向冒泡排序方法如下:Fori=lto5Ifa(i)>a(5-i+l)Thent=a(i):a(i)=a(5-i+
5、l):a(5-i+l)=tEndifForj=i+lto5-iIfa(j)<a(i)thent=a(i):a(i)=a(j):a(j)=tEndifIfa(j)>a(5-i+l)Thent=a(j):a(j)=a(5-i+l):a(5-i+l)=tEndifNextjNexti三、冒泡排序的改进方法之二考虑冒泡排序的基本思想,我们发现每一轮的比较交换中都有重复的比较交换,我们可以考虑结合选择排序的思想,在内循环中标示出交换发生的位置,这样可以避免一些重复的比较交换。具体的算法如下:Fori=lto4n二n+1Forj=5tonstep-1m=
6、m+lIfa(j)&l切(卜1)Thent=a(j):a(j)=a(j-l):a(j-l)=tn=jEndifNextjNexti四、算法性能比较对于传统的冒泡排序算法,每次比较都有可能交换数据,因此最多要进行n×(n-1)/2次数据的两两交换,所以传统冒泡排序算法的平均时间复杂度为0("2)。传统的冒泡排序算法整个排序过程需要轮,而双向冒泡排序法只需要n/2轮,若记录的初始状态是(从小到大)的,则一轮扫描即可完成排序,所需的关键比较和记录移动的次数分别达到最小值n・l和0,即双向冒泡排序算法最好的时间复杂度为O(n);若初始记录为反序的则需
7、要进行n/2轮排序。对于标志位冒泡排序来说,从这种算法可以看出,若记录的初始状态是正序(从小到大)的,则一趟扫描即可完成排序。所需的比较和记录移动的次数分别达到最小值和0,即算法最好的吋间复杂度为O(n);若初始记录是反序(从大到小)的,则需要进行趟排序,每趟排序要进行n・i次关键宇的比较,且每次比较都必须移动记录三次来达到交换记录位置。在这情况下比较和移动次数达到最大值:比较次数为Cmax=n(n-l)/2,移动次数:Mmax=3n(n-l)/2,因此这种改进方法的最坏吋间复杂度也为O(nA2)o在平均情况下,算法可能在中间的某一趟排序完后就终止,但总
8、的比较次数仍为0("2),所以算法的平均吋间复杂度为0("2)。因此,这种算法最
此文档下载收益归作者所有