高悬赏:C语言题,依次输入10个数,按从大到小的顺序输出(要求用插入法排序),哪位大神能给我题的C
高悬赏:C语言题,依次输入10个数,按从大到小的顺序输出(要求用插入法排序),哪位大神能给我题的C/C++源码或解析,大谢!...
高悬赏:C语言题,依次输入10个数,按从大到小的顺序输出(要求用插入法排序),哪位大神能给我题的C/C++源码或解析,大谢!
展开
展开全部
#include <stdio.h>
int main()
{
int a[10];
int i, j, k, value;
for (i = 0; i < 10; ++i){
scanf ("%d", &value);
for (j = 0; j < i; ++j){ //判断小于输入数的第一个数的位置
if (a[j] < value)break;
}
if (j >= i){//如果移动到了数组的末尾,就将value插入到数组末尾
a[j] = value;
}
else {
for (k = i; k > j; --k){//将j到i-1的数后移一位
a[k] = a[k-1];
}
a[j] = value;//将value插入到j的位置
}
}
for (i = 0; i < 10; ++i){//打印排序结果
printf ("%5d", a[i]);
}
printf ("\n");
return 0;
}
int main()
{
int a[10];
int i, j, k, value;
for (i = 0; i < 10; ++i){
scanf ("%d", &value);
for (j = 0; j < i; ++j){ //判断小于输入数的第一个数的位置
if (a[j] < value)break;
}
if (j >= i){//如果移动到了数组的末尾,就将value插入到数组末尾
a[j] = value;
}
else {
for (k = i; k > j; --k){//将j到i-1的数后移一位
a[k] = a[k-1];
}
a[j] = value;//将value插入到j的位置
}
}
for (i = 0; i < 10; ++i){//打印排序结果
printf ("%5d", a[i]);
}
printf ("\n");
return 0;
}
更多追问追答
追问
确定第一个for是++i而不是i++
追答
额,这两个在这里的效果是一样的,两个都可以
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询