Brief : 闲的无聊随便找了个题想要练练手熟悉下感觉,结果一直没过。并且到现在我也不知到问题出现在哪里了,如果有人知道可以在评论区下留言告诉我,感激不尽。
题目:
输入一组数据。
该组数据只有一行,为一个整数n,保证33.33%的n在int范围内,33.33%的n在long long范围内,33.33%的n超过long long范围。
把这个数的每一位加起来,如果加起来的和的位数多于1位的话,就继续将这个数的每一位数字加起来,直到最后只有一位数为止。
样例:
输入:987
输出:6
代码1 (没有Accept 原):
#include <stdio.h>
int main(int argc, char const *argv[]){
char n;
int sum = 0;
while(n=getchar()){
if (n == '\n') break;
sum += n-48;
if (sum>=10) sum = sum/10 + sum%10;
}
printf("%d\n", sum);
return 0;
}
代码2 (Accept 转):
#include <stdio.h>
#define MAX 100000000
char arr[MAX];
int main(){
int ans = 0;
scanf("%s", arr);
for (int i = 0; arr[i] != '\0'; i++)
ans += arr[i] - '0';
while (ans > 9) {
int tmp = ans;
ans = 0;
while (tmp > 0) {
ans += tmp % 10;
tmp /= 10;
}
}
printf("%d\n", ans);
return 0;
}