C语言:采用冒泡排序方法,对10个数按由小到大的的顺序排序

C语言:采用冒泡排序方法,对10个数按由小到大的的顺序排序... C语言:采用冒泡排序方法,对10个数按由小到大的的顺序排序 展开
 我来答
问明6E
高粉答主

2019-05-17 · 每个回答都超有意思的
知道答主
回答量:279
采纳率:100%
帮助的人:13万
展开全部

代码如下(对10个整数进行升序排序):

#include<stdio.h>

int main()

{

int i,j,t,a[10]={5,4,8,3,6,9,7,222,64,88};

//排序

for(i=1;i<10;i++)//外循环控制排序趟数,n个数排n-1趟

{

for(j=0;j<10-1;j++)//内循环每趟比较的次数,第j趟比较n-i次

{

if(a[j]>a[j+1])//相邻元素比较,逆序则交换

{

t=a[j];

a[j]=a[j+1];

a[j+1]=t;

}

}

}

printf("排序后的结果是:\n");

for(i=0;i<10;i++)

{

printf("%d",a<i>);

}

printf("\n");

return 0;

}

冒泡法:

算法分析:如果有n个数,则要进行n-1趟比较。在第1趟比较中要进行n-1次相邻元素的两两比较,在第j趟比较中要进行n-j次两两比较。比较的顺序从前往后,经过一趟比较后,将最值沉底(换到最后一个元素位置),最大值沉底为升序,最小值沉底为降序。

扩展资料:

include用法:

#include命令预处理命令的一种,预处理命令可以将别的源代码内容插入到所指定的位置;可以标识出只有在特定条件下才会被编译的某一段程序代码;可以定义类似标识符功能的宏,在编译时,预处理器会用别的文本取代该宏。

插入头文件的内容

#include命令告诉预处理器将指定头文件的内容插入到预处理器命令的相应位置。有两种方式可以指定插入头文件:

1、#include<文件名>

2、#include"文件名"

如果需要包含标准库头文件或者实现版本所提供的头文件,应该使用第一种格式。如下例所示:

#include<math.h>//一些数学函数的原型,以及相关的类型和宏

如果需要包含针对程序所开发的源文件,则应该使用第二种格式。

采用#include命令所插入的文件,通常文件扩展名是.h,文件包括函数原型、宏定义和类型定义。只要使用#include命令,这些定义就可被任何源文件使用。如下例所示:

#include"myproject.h"//用在当前项目中的函数原型、类型定义和宏

你可以在#include命令中使用宏。如果使用宏,该宏的取代结果必须确保生成正确的#include命令。例1展示了这样的#include命令。

【例1】在#include命令中的宏

#ifdef _DEBUG_

#define MY_HEADER"myProject_dbg.h"

#else

#define MY_HEADER"myProject.h"

#endif

#include MY_HEADER

当上述程序代码进入预处理时,如果_DEBUG_宏已被定义,那么预处理器会插入myProject_dbg.h的内容;如果还没定义,则插入myProject.h的内容。

天天向上李亚飞
2016-08-09 · 学习——就要天天向上!
天天向上李亚飞
采纳数:540 获赞数:3878

向TA提问 私信TA
展开全部

这是原始的冒泡法:

main()
{ int a[10]={……},i,j,t;

  for( i=0;i<10;i++ )
     printf("%5d",a[i]);
     
  for( i=0;i<10;i++ )
     for( j=0;j<10-1;j++ )
        if( a[j]>a[j+1] )
           { t=a[j];
             a[j]=a[j+1];
             a[j+1]=t;
           }
           
 for( i=0;i<10;i++ )
     printf("%5d",a[i]);  
}


这是改良后的冒泡排序:

main()
{ int a[10]={……},i,j,t;

  for( i=0;i<10;i++ )
     printf("%5d",a[i]);
     
  for( i=0;i<10-1;i++ )
     for( j=i+1;j<10;j++ )
        if( a[i]>a[j] )
           { t=a[i];
             a[i]=a[j];
             a[j]=t;
           }
           
 for( i=0;i<10;i++ )
     printf("%5d",a[i]);  
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
浪迹天涯的流星
2016-05-30 · 知道合伙人教育行家
浪迹天涯的流星
知道合伙人教育行家
采纳数:8922 获赞数:81537
对于基本办公软件比较擅长。

向TA提问 私信TA
展开全部
冒泡排序方法的代码如下:
#include<stdio.h>
void main()
{ int i,j,k,a[10];
printf("qingshurushuzu :\n");
for(i=1;i<=10;i++)
scanf("%d",&a[i]);
for(i=1;i<=9;i++)
{for(j=i+1;j<=10;j++)
{if(a[j]>a[i])
{k=a[i];a[i]=a[j];a[j]=k;}
}
}
printf("qingyoudadaoxiaoshuchu: \n");
for(i=1;i<=10;i++)
printf("%d\n",a[i]);
}

这个是我找的,知道里面没有的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
521bgm
2019-12-21 · TA获得超过1950个赞
知道小有建树答主
回答量:4607
采纳率:0%
帮助的人:147万
展开全部
代码如下(对10个整数进行升序排序):

#include<stdio.h>

int main()

{

int i,j,t,a[10]={5,4,8,3,6,9,7,222,64,88};

//排序

for(i=1;i<10;i++)//外循环控制排序趟数,n个数排n-1趟

{

for(j=0;j<10-1;j++)//内循环每趟比较的次数,第j趟比较n-i次

{

if(a[j]>a[j+1])//相邻元素比较,逆序则交换

{

t=a[j];

a[j]=a[j+1];

a[j+1]=t;

}

}

}

printf("排序后的结果是:\n");

for(i=0;i<10;i++)

{

printf("%d",a<i>);

}

printf("\n");

return 0;

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
DoramiHe
推荐于2017-11-24 · 知道合伙人互联网行家
DoramiHe
知道合伙人互联网行家
采纳数:25332 获赞数:59542
2011年中山职业技术学院毕业,现担任毅衣公司京东小二

向TA提问 私信TA
展开全部
用函数调用的方法编程:从键盘输入10个数,用冒泡法对10个数按由小到大顺序排序,并输出。/***...
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(7)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式