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;
}