C語言實驗——各位數字之和排序
題目描述
給定n個正整數,根據各位數字之和從小到大進行排序。
輸入
輸入數據有多組,每組數據佔一行,每行的第一個數正整數n,表示整數個數,後面接n個正整數。當n爲0時,不作任何處理,輸入結束。
輸出
輸出每組排序的結果。
示例輸入
示例輸出
注意題目爲各位數字之和,不注意是會吃大虧的。。。
#include <stdio.h>
void sort(int a[],int n);//冒泡排序
int isum(int n);//各位之和
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 != n-1)
printf("%d ",a[i]);
else
printf("%d\n",a[i]);
}
}
return 0;
}
void sort(int a[],int n)//冒泡排序
{
int i,j;
int t;
for(i=n-1-1; i >=0; i--)
{
for(j=0; j<=i; j++)
{
if(isum(a[j]) > isum(a[j+1]))
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
}
}
int isum(int n)//各位之和
{
int s=0;
do
{
s += n % 10;
n /= 10;
}while(n);
return s;
}