ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CF919B Perfect Number 题解

2021-12-21 20:04:35  阅读:125  来源: 互联网

标签:Perfect 10 10000 cur int 题解 sum Number while


Content

给定一个数字 \(k\),求出第 \(k\) 小的各数位和为 \(10\) 的数。

数据范围:\(1\leqslant k\leqslant 10000\)。

Solution

这题为什么不可以打表解决呢?我们可以直接枚举、判断,获得所有第 \(1\sim10000\) 个各数位和为 \(10\) 的数,然后就可以直接输出答案了。

Code

int k, f[10007], cur;

int main() {
	while(f[0] < 10000) {
		int sum = 0, p = cur;
		while(p) {
			sum += p % 10;
			p /= 10;
		}
		if(sum == 10)	f[++f[0]] = cur;
		cur++;
	}
	getint(k);
	writeint(f[k]);
	return 0;
}

标签:Perfect,10,10000,cur,int,题解,sum,Number,while
来源: https://www.cnblogs.com/Eason-AC/p/15716791.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有