小U数数问题

问题描述

小U正在数偶数,从 0,2,4,6,8,10,12,...0,2,4,6,8,10,12,... 开始,依次将这些数连在一起,形成一个无穷长的字符串,例如:"0246810121416..."。小U想知道这个字符串中的第 nn 个字符是什么。


测试样例

样例1:

输入:n = 6

输出:1

样例2:

输入:n = 10

输出:1

样例3:

输入:n = 15

输出:8

解题思路

  1. 理解序列生成规则:首先,明确序列是如何生成的。例如,本题中的序列是由偶数组成的。
  2. 生成序列并构建字符串:根据序列生成规则,生成足够长的序列,并将其转换为字符串。
  3. 查找目标字符:在生成的字符串中找到目标位置的字符。

具体步骤

  1. 生成序列

    • 使用循环或递归生成序列。
    • 对于偶数序列,可以从 0 开始,每次增加 2
  2. 构建字符串

    • 将生成的序列中的每个数字转换为字符串,并连接起来。
    • 使用字符串拼接操作(如 +=)来构建最终的字符串。
  3. 查找目标字符

    • 在生成的字符串中,找到目标位置的字符。
    • 注意字符串索引从 0 开始,所以目标位置的字符索引是 n-1

代码实现

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int solution(int n) {
    string result = "";
    int num = 0;
    
    // 生成偶数并连接成字符串
    while (result.length() < n) {
        result += to_string(num);
        num += 2;
    }
    
    // 返回第 n 个字符
    return result[n - 1] - '0'; // 注意:字符串索引从 0 开始
}

int main() {
    cout << (solution(6) == 1) << endl;
    cout << (solution(10) == 1) << endl;
    cout << (solution(15) == 8) << endl;
    return 0;
}

关键步骤解释

  1. 生成偶数并连接成字符串

    • 使用 while 循环,直到 result 字符串的长度超过 n
    • 每次循环中,将当前的偶数 num 转换为字符串并追加到 result 中。
    • 然后将 num 增加 2,以生成下一个偶数。
  2. 返回第 n 个字符

    • 由于字符串索引从 0 开始,所以第 n 个字符的索引是 n-1
    • 将字符转换为数字并返回。

总结

  • 理解序列生成规则:明确序列是如何生成的。
  • 生成序列并构建字符串:根据规则生成序列,并将其转换为字符串。
  • 查找目标字符:在生成的字符串中找到目标位置的字符。
相关推荐
allan bull8 分钟前
在节日中寻找平衡:圣诞的欢乐与传统节日的温情
人工智能·学习·算法·职场和发展·生活·求职招聘·节日
似水এ᭄往昔24 分钟前
【C++】--封装红⿊树实现mymap和myset
开发语言·数据结构·c++·算法·stl
咕噜企业分发小米26 分钟前
腾讯云向量数据库HNSW索引如何更新?
人工智能·算法·腾讯云
charlie11451419129 分钟前
嵌入式现代C++教程:C++98——从C向C++的演化(3)
c语言·开发语言·c++·笔记·学习·嵌入式
lcreek31 分钟前
LeetCode215. 数组中的第K个最大元素、LeetCode912. 排序数组
python·算法·leetcode
moonquakeTT34 分钟前
C++:深拷贝与浅拷贝
c++
程序员zgh36 分钟前
C语言 指针用法与区别(指针常量、常量指针、指针函数、函数指针、二级指针)
c语言·开发语言·jvm·c++
Einsail1 小时前
天梯赛题解(3-6)
算法
杜子不疼.1 小时前
【LeetCode 852 & 162_二分查找】山脉数组的峰顶索引 & 寻找峰值元素
算法·leetcode·职场和发展
山楂树の1 小时前
搜索插入位置(二分查找)
数据结构·算法