printf("input 10 numbers:\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
printf("\n");
for(j=0;j<9;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;
}
printf("the sored numbers :\n");
for(i=0;i<10;i++)
printf("%d",a[i]);
printf("\n");
return 0;
}
去请大神告诉我我的代码哪里有错误?谢谢
#include <stdio.h>
int main()
{
int a[10];
int i,j,t;
printf("input 10 numbers:\n");
for(i=0;i<10;i++)
scanf("%d\n",&a[i]);
printf("\n");
for(j=0;j<9;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;
}
printf("the sored numbers :\n");
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
return 0;
}
扩展资料:
此程序使用冒泡排序,算法稳定性:
冒泡排序就是把小的元素往前调或者把大的元素往后调。比较是相邻的两个元素比较,交换也发生在这两个元素之间。所以,如果两个元素相等,是不会再交换的;
如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来,这时候也不会交换,所以相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法。
参考资料:
程序没有大的问题,已经修改后运行通过,请仔细比对改动:
#include <stdio.h>#include <stdio.h> int main() { int a[10]; int i,j,t;
include <stdio.h> int main(){ int a[10];int i,j,t;printf("input 10 numbers:\\n");for(i=0;i<10;i++)scanf("%d\\n",&a[i]);printf("\\n");for(j=0;j<9;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;} printf("th...
#include<stdio.h> int main() { int a[10]; int pos,j, i,t; for...
int main(){ int a[10];int pos,j, i,t;for(i=0;i<10;i++)scanf("%d",&a[i]);for(i=0;i<9;i++)\/\/写错成j++ { pos=i;for(j=i+1;j<=9;j++)\/\/要等于 {if(a[pos]<a[j]){ t=a[pos];a[pos]=a[j];a[j]=t;} } } for(i=0;i<10;i++)printf("%d"...
1.定义一个长度为10的整型数组,然后用键盘输入任意数字给这10个变量...
int main(){ int a[10];int i,j,t;printf("请输入一维数组的值:\\n");for(i=0;i<=9;i++){ scanf("%d",&a[i]);} printf("数值从小到大排列:\\n");for(i=1;i<=9;i++){ for(j=0;j<=9-i;j++){ if(a[j]>a[j+1]){ t=a[j];a[j]=a[j+1];a[j+1]=t;...
C语言键盘输入10个整数,按大小顺序输出要求用选择法。输出排序后的整数...
#include<stdio.h> int main() { int a[10]; int i,t,j,m; for(i=0;i<=9;i++) { scanf("%d ",&a[i]); } for(i=0;i<9;i++) { t=i; for(j=i+1;j<=9;j++) if(a[t]<a[j]) t=j; ... 展开 唯爱Daffodils | 浏览1278 次 |举报 我有更好的答案推荐于2017-12-15 1...
c语言#include<stdio.h> #define N 10 main() { int a[10],i,j,t...
首先原程序有以下几个问题:1.在排序时,for(i=0;i<N-1;j++),不能每次j++ 否则死循环;2.if(a[j]>a[j+1]),这里的排序是递增的,但是后面的输出提示是递减的;3.printf("Minimum:a[9]=%d\\n",a[0]),不能说输出a[9]但是传参数用a[0];4.后面打印的一些输出与题意无关,并且在...
#include<stdio.h> void main() { int i,j,t; printf("please inpu 10...
include<stdio.h> void main(){ int a[10],i,j,t;printf("please inpu 10 numbers:\\n");for (i=0;i<10;i++)scanf("%d",&a[i]);for(j=0;j<10;j++){ for(i=0;i<10-1-j;i++){ if(a[i]>a[i+1]){ t=a[i];a[i]=a[i+1];a[i+1]=t;} } } printf("...
c语言求详解
include<stdio.h>\/\/这是C的一个标准输入输出数。下面使用的scanf printf这些函数就是在这个头文件里面声明的。int main(){ int a[10],i,j,t;\/\/声明变量 printf("input 10 numbers:\\n");\/\/提示输出 for(i=0;i<10;i++)\/\/循环十次,分别输入十个数,scanf("%d",&a[i]);\/\/读入一个...
#include<stdio.h> int main() { int a[10],i,x,k; for(i=0;i<9;i...
已经改好了:include<stdio.h> int main(){ int a[10],i,x,k;for(i=0;i<9;i++)scanf("%d",&a[i]);scanf("%d",&x);if(a[0]<a[1]){ for(i=0;i<9;i++)if(a[i]>x) break;} else { for(i=0;i<9;i++)if(a[i]<x) break;} k=i;for(i=8;i>=k;i--)...
C语言(简单的)编写程序输入一维整形数组a[10],将其按由小到大排序后输 ...
这个应该用起泡法排序算法。include<stdio.h> int main(){ int a[10];int i,j,k;printf("input 10 numbers:\\n");for(i=0;i<10;i++){\/\/输入十个数,一次循环输入10次 scanf("%d",&a[i]);printf("\\n");\/\/换行 for(j=0;j<9;j++)\/\/从小到大换行经典方法四行 for(i=0;i<...
2、使用数组输入10个数,逆序输出。要求使用第一个数与在最后一个数交 ...
include <stdio.h> int main(){ int i,j,t,a[10];for(i=0; i<10; i++)scanf("%d",&a[i]);for(i=0,j=9; i<j; i++,j--){ t=a[i];a[i]=a[j];a[j] =t;} for(i=0; i<10; i++)printf("%d ",a[i]);return 0;} ...