C语言实验——各位数字之和排序
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
给定n个正整数,根据各位数字之和从小到大进行排序。
输入
输入数据有多组,每组数据占一行,每行的第一个数正整数n,表示整数个数,后面接n个正整数。当n为0时,不作任何处理,输入结束。
输出
输出每组排序的结果。
示例输入
2 1 2 3 121 10 111 0
示例输出
1 2 10 111 121
代码如下:
#include<stdio.h>
int shuhe(int m);void main()
{
int n, i, j, k, a[1000], b[1000], t, h;
while(scanf("%d", &n)!=EOF)
{
if(n == 0) break;
else
{
for(i = 0; i <= n - 1; i++)
{
scanf("%d", &a[i]);
b[i] = shuhe(a[i]);
}
for(i = 0; i <= n - 2; i++)
{
k = i;
for(j = i + 1; j <= n - 1; j++)
if(b[k] > b[j])
k = j;
if(k != i)
{t = b[k]; b[k] = b[i]; b[i] = t;
h = a[k]; a[k] = a[i]; a[i] = h;}
}
for(i = 0; i <= n - 1; i++)
{
if(i == n - 1)
printf("%d\n", a[i]);
else
printf("%d ", a[i]);
}
}
}
}
int shuhe(int m)
{
int s = 0;
while(m > 0)
{
s = s + m % 10;
m = m / 10;
}
return s;
}