C语言四个数从小到大排列的程序

C语言四个数从小到大排列的程序,第1张

汗,。。。。。任意一本家才上都有

什么冒泡

选择

插入排序都是啊

、排序算法

(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的数从小到大排列。等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/9818925.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-02
下一篇2023-05-02

发表评论

登录后才能评论

评论列表(0条)

    保存