题目链接如下:
Online Judge
我的代码如下:文章来源:https://www.toymoban.com/news/detail-697364.html
#include <cstdio>
int T, N;
bool flag;
int cal(int k){
int ans = k;
while(k){
ans += k % 10;
k /= 10;
}
return ans;
}
int main(){
scanf("%d", &T);
for(int i = 0; i < T; ++i){
scanf("%d", &N);
flag = false;
for(int j = N - 45; j < N; ++j){
if(cal(j) == N){
flag = true;
printf("%d\n", j);
break;
}
}
if(!flag){
printf("0\n");
}
}
return 0;
}
按照刘汝佳方法写的代码如下:文章来源地址https://www.toymoban.com/news/detail-697364.html
#include <cstdio>
const int maxN = 100005;
int T, N;
int gen[maxN];
int cal(int k){
int ans = k;
while(k){
ans += k % 10;
k /= 10;
}
return ans;
}
int main(){
for(int i = 1; i < maxN; ++i){
if(cal(i) < maxN && gen[cal(i)] == 0){
gen[cal(i)] = i;
}
}
scanf("%d", &T);
for(int i = 0; i < T; ++i){
scanf("%d", &N);
printf("%d\n", gen[N]);
}
return 0;
}
到了这里,关于1583 - Digit Generator (UVA)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!