
汗,。。。。。任意一本家才上都有
什么冒泡
选择
插入排序都是啊
、排序算法
(1)分析
因为每一趟排序都使有序区增加了一个气泡,在经过n-1趟排序之后,有序区中就有n-1个气泡,而无序区中气泡的重量总是大于等于有序区中气泡的重量,所以整个冒泡排序过程至多需要进行n-1趟排序。
若在某一趟排序中未发现气泡位置的交换,则说明待排序的无序区中所有气泡均满足轻者在上,重者在下的原则,因此,冒泡排序过程可在此趟排序后终止。为此,在下面给出的算法中,引入一个布尔量exchange,在每趟排序开始前,先将其置为FALSE。若排序过程中发生了交换,则将其置为TRUE。各趟排序结束时检查exchange,若未曾发生过交换则终止算法,不再进行下一趟排序。
(2)具体算法
void
BubbleSort(SeqList
R)
{
//R(ln)是待排序的文件,采用自下向上扫描,对R做冒泡排序
int
i,j;
Boolean
exchange;
//交换标志
for(i=1;i<n;i++){
//最多做n-1趟排序
exchange=FALSE;
//本趟排序开始前,交换标志应为假
for(j=n-1;j>=i;j--)
//对当前无序区R[in]自下向上扫描
if(R[j+1]key<R[j]key){//交换记录
R[0]=R[j+1];
//R[0]不是哨兵,仅做暂存单元
R[j+1]=R[j];
R[j]=R[0];
exchange=TRUE;
//发生了交换,故将交换标志置为真
}
if(!exchange)
//本趟排序未发生交换,提前终止算法
return;
}
//endfor(外循环)
}
//BubbleSort
4、算法分析
(1)算法的最好时间复杂度
若文件的初始状态是正序的,一趟扫描即可完成排序。所需的关键字比较次数C和记录移动次数M均达到最小值:
Cmin=n-1
Mmin=0。
冒泡排序最好的时间复杂度为O(n)。
(2)算法的最坏时间复杂度
若初始文件是反序的,需要进行n-1趟排序。每趟排序要进行n-i次关键字的比较(1≤i≤n-1),且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:
Cmax=n(n-1)/2=O(n2)
Mmax=3n(n-1)/2=O(n2)
冒泡排序的最坏时间复杂度为O(n2)。
(3)算法的平均时间复杂度为O(n2)
虽然冒泡排序不一定要进行n-1趟,但由于它的记录移动次数较多,故平均时间性能比直接插入排序要差得多。
(4)算法稳定性
冒泡排序是就地排序,且它是稳定的。
Private Sub Command1_Click()
Dim i%, j%, s!(1 To 3), t!
For i = 1 To 3 '几个数改成几
s(i) = Val(InputBox("请输入第" & i & "个数:"))
Next
For i = 1 To 3
For j = i + 1 To 3
If s(j) < s(i) Then t = s(i): s(i) = s(j): s(j) = t
Next
Print s(i);
Next
End Sub
冒泡法!在我们写程序的时候,通常都会对一组数据进行排序,常用的方法有冒泡法和选择法,我主要写下我对冒泡法的理解和心得。
冒泡法:顾名思义,就是把小的数据向前排,也就是向上浮起,并因此进行排序。
例:
#include "stdioh" 包含头文件
void main() 主函数
{
int a[10],t,i,j; 定义要用的数据和数祖
printf("input the ten number:\n"); 显示输出
for(i=0;i<10;i++)
scanf("%d",&a[i]); 利用循环接受数据
for(j=0;j<10;j++)
for(i=0;i<9-j;i++)
if(a[i]>a[i+1])
{
t=a[i];
a[i]=a[i+1]; 这个就是冒泡的要义了,这个语句是进行冒泡的,下面会有解释
a[i+1]=t;
}
for(i=0;i<10;i++)
printf("%d\t",a[i]); 循环输出排序后的数据
}
以上就是关于C语言四个数从小到大排列的程序全部的内容,包括:C语言四个数从小到大排列的程序、谁能用vb帮我编辑一个从小到的的数字排列程序、在c语言编程中如何将1-10的数从小到大排列。等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)