Problem Description
给定n个正整数,根据各位数字之和从小到大进行排序。
Input
输入数据有多组,每组数据占一行,每行的第一个数正整数n,表示整数个数,后面接n个正整数。当n为0时,不作任何处理,输入结束。n<=10
Output
输出每组排序的结果。
Sample Input
2 1 2
3 121 10 111
0
Sample Output
1 2
10 111 121
代码:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
int f(int n)//各位之和
{
int s=0;
do
{
s=s+n%10;
n=n/10;
}
while(n);
return s;
}
void sort(int a[],int n)//冒泡排序
{
int i,j,t;
for(i=0;i<n-1;i++)
{
for(j=0;j<n-i-1;j++)
{
if(f(a[j])>f(a[j+1]))
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
}
}
int main()
{
int n,i;
int a[100];
while(scanf("%d",&n), n)
{
for(i=0; i<n; i++)//输入数组
scanf("%d",&a[i]);
sort(a,n);//排序
for(i=0; i<n; i++)//输出
{
if(i==0)
printf("%d",a[i]);
else
printf(" %d",a[i]);
}
printf("\n");
}
return 0;
}