#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int main()
{
char ch;
while(1)
{
int sum=0;
while(scanf("%c",&ch)&&ch!='\n')
{
sum+=ch-'0';
}
if(sum==0) break;
if(sum%9==0) sum=9;
else sum=sum%9;
printf("%d\n",sum);
}
return 0;
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int main()
{
char ch;
while(1)
{
int sum=0;
while(scanf("%c",&ch)&&ch!='\n')
{
sum+=ch-'0';
}
if(sum==0) break;
if(sum%9==0) sum=9;
else sum=sum%9;
printf("%d\n",sum);
}
return 0;
}
经测试,整数位数有1000位,只能有字符串运算,数根就是sum%9的结果,如果sum%9=0,数根是9,这是因为一个整数模9的结果与这个整数的各位数字之和模9的结果相同