OJ1188各位数字之和排序

Problem Description
给定n个正整数,根据各位数字之和从小到大进行排序。

Input
输入数据有多组,每组数据占一行,每行的第一个数正整数n,表示整数个数,后面接n个正整数。当n为0时,不作任何处理,输入结束。n<=10

Output
输出每组排序的结果。

Sample Input
3 230 59 110
5 199 220 108 235 120
0

Sample Output
110 230 59
120 220 108 235 199

#include<iostream>
using namespace std;
int main()
{
	int i,j,n,t,a[10],b[10];
	while((cin>>n)!="EOF"&&(n!=0))
	{
		for(i=0;i<n;i++) b[i]=0;
		for(i=0;i<n;i++) 
		{
			cin>>a[i];
			t=a[i];
			while(t!=0)
			{
				b[i]+=t%10;
				t/=10;
			}
		}
		for(i=0;i<n;i++)
		for(j=i+1;j<n;j++)
		if(b[i]>b[j])
		{
			t=b[i];b[i]=b[j];b[j]=t;
			t=a[i];a[i]=a[j];a[j]=t;
		}
		for(i=0;i<n;i++)
		{
			if(i==n-1) cout<<a[i]<<endl;
			else cout<<a[i]<<" ";
		}
	}
	return 0;
}

OJ上显示编译错误,emmm,没用C语言用的C++,EOF使用时没加双引号竟然显示未定义—作为小白还不太能理解。
其次,加上EOF双引号后,在自己电脑上编译器上倒是没问题了,运行也没有问题,但是在上传题目时还是不行,显示着编译错误。倒是没摸着头脑。
还请大佬们有懂的能否不吝赐教一波呢,然后再帮忙找找问题提出来,我会认真反思和改正的。

上一篇:120.防线 算法竞赛进阶指南


下一篇:阶乘