题解 | #数字序列中某一位的数字#
数字序列中某一位的数字
https://www.nowcoder.com/practice/29311ff7404d44e0b07077f4201418f5
- 要分区间,一位数的,两位数的,0-9,10-99,100-999
- 基于区间的起点,定位n在哪个数字
- 最后基于求余,找到数字上的具体位置
struct Solution{ } impl Solution { fn new() -> Self { Solution{} } /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param n int整型 * @return int整型 */ pub fn findNthDigit(&self, n: i32) -> i32 { // write code here if n < 0 { return -1; // or handle the error in your preferred way } let mut n = n as usize; // Convert n to usize for indexing convenience let mut digits_count = 1; let mut base = 1; // Determine the range of numbers with the given number of digits while n > digits_count * 9 * base { n -= digits_count * 9 * base; digits_count += 1; base *= 10; } // Find the actual number let number = base + (n - 1) / digits_count; // Find the position of the digit within the number let position = (n - 1) % digits_count; // Extract the digit let digit = number.to_string().chars().nth(position).unwrap(); digit.to_digit(10).unwrap() as i32 } }#rust#