关键:
if (!vis[i]) printf("%d\n", i);
vis[d(i)] = true;
完整代码:
#include<cstdio>
const int maxn = 1000001;
bool vis[maxn];
inline int d(int n)
{
int sum = n;
while (n)
{
sum += n % 10;
n /= 10;
}
return sum;
}
int main()
{
for (int i = 1; i < maxn; ++i)
{
if (!vis[i]) printf("%d\n", i);
vis[d(i)] = true;
}
return 0;
}

本文提供了一段C++代码,用于解决UVA在线评测系统中的一道题目。该算法通过计算并打印出所有未被访问过的整数,同时标记它们的数字和,实现了题目的要求。
351

被折叠的 条评论
为什么被折叠?



