CF1177A Digits Sequence (Easy Edition) 题解

Content

一个序列由从 \(1\) 开始的数字不断在末端拼接,就像这样:\(12345678910111213141516...\)。现在,给定一个数字 \(k\),请输出这个序列的第 \(k\) 个数字。

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

Solution

这题的数据范围不是很大,我们可以直接模拟得到长度为 \(10000\) 的序列,然后就可以直接输入输出了。

Code

int n = 1, cur, d[10007];

int main() {
	while(cur <= 10000) {
		int p = n, digit[17] = {0};
		while(p) {
			digit[++digit[0]] = p % 10;
			p /= 10;
		}
		_rep(i, digit[0], 1)	d[++cur] = digit[i];
		n++;
	}
	int x;
	getint(x);
	writeint(d[x]);
	return 0;
}
posted @ 2021-12-17 14:26  Eason_AC  阅读(52)  评论(0)    收藏  举报