问题如图 好像总有一个值赋不上,求大神给小白讲讲到底问题在哪
代码如下
#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;
}
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;
#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;
}
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;
}