C语言 从键盘随机输入10个整数,将他们从小到大排序后输出

问题如图 好像总有一个值赋不上,求大神给小白讲讲到底问题在哪

代码如下

#include<stdio.h>
int main ()
{
int i,n,x,y,m,w,k;
int a[10];
int b[10];

for (i=0;i<10;i++)
{
scanf("%d",&a[i]);
fflush(stdin);
}

for (i=0;i<10;i++)
{
x=0;
y=0;
m=0;
for (n=0;n<10;n++)
{
k=0;
if (i==n)
{
}
else
{
if (a[i]>a[n])
{
x=x+1; //计数
}
else if (a[i]<a[n])
{
y=y+1; //计数
}
else
{
m=m+1; //值相同的个数
}
for (w=0;w<i;w++)
{
if (a[w]==a[i])
{
k=k+1;
}
}
}
}
b[x+k]=a[i];
}

for (i=0;i<10;i++)
{
printf("\n%d",b[i]);
}

printf("\n");

return 0;
}

#include<stdio.h>

int main ()

{

int i,n,k,a[10];

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

    scanf("%d",&a[i]);

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

  for (n=0;n<9-i;n++)

    if(a[n]>a[n+1])

    {

     k=a[n];a[n]=a[n+1];a[n+1]=k;

    }

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

  printf("\n%d",a[i]);

printf("\n");

return 0;

}


温馨提示:答案为网友推荐,仅供参考
第1个回答  2017-08-17
你这样做复杂了,用冒泡排序就可以实现。
int a[10];
int i, j, temp;
// 输入10个整型数据
printf("Please input ten numbers: \n");
for (i = 0; i < 10; i++)
scanf("%d", &a[i]);
// 排序
for (i = 0; i < 9; i++) // 10个数,10 - 1轮冒泡,每一轮都将当前最大的数推到最后
{
for (j = 0; j < 9 - i; j++) // 9 - i,意思是每当经过一轮冒泡后,就减少一次比较
if (a[j] > a[j+1])
{
temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
}

// 打印排序结果
for (i = 0; i < 10; i++)
printf("%d\n", a[i]);

return 0;
第2个回答  2017-08-25
#include <stdio.h>
#include <stdlib.h>
int cmp(const void *a, const void *b)
{
return *(int *)a - *(int *)b;//返回比较值
}
int main()
{
int a=10;
int *xy = (int *)malloc(a * sizeof(int));//初始化内存
for (int i = 0; i < a; i++)//读取存入内存
{
scanf("%d", &xy[i]);
}
qsort(xy, a, sizeof(xy[0]), cmp);//排序
for (int i = 0; i < a; i++)//输出排序后内容
{
printf("%d ", xy[i]);
}
getchar(); getchar(); getchar(); getchar();//暂停查看
return 0;
}

第3个回答  2017-08-25
把fflush(stdin);删除——放在那里有害无益!
第4个回答  2017-08-14
#include<stdio.h>
int main(void) {
int a[10],v;
for (int i = 0; i < 10; i++) {
scanf("%d ", &a[i]);

}
for (int j = 0; j < 10; j++) {
for (int k = 0; k < j; k++) {
if(a[k]>=a[j]){
v = a[j];
a[j] = a[k];
a[k] = v;
}
}
}
for (int d = 0; d < 10; d++) {
printf("a[%d]=%d\n", d, a[d]);
}
return 0;
}

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网