440. 字典序的第K小数字 题解

https://leetcode-cn.com/problems/k-th-smallest-in-lexicographical-order/

复制代码
#include<bits/stdc++.h>
using namespace std;
int getSteps(int curr, long n) {
    int steps = 0;
    long first = curr;
    long last = curr;
    cout<<"curr="<<curr<<endl;
    while (first <= n) {
        //字典树按层次遍历
        cout<<"first="<<first<<"   last="<<last<<endl;
        steps += min(last, n) - first + 1;
        first = first * 10;
        last = last * 10 + 9;
    }
    return steps;
}

int findKthNumber(int n, int k) {
    int curr = 1;
    k--;
    while (k > 0) {
        int steps = getSteps(curr, n);
        //统计以curr开始的字典树节点数量
        cout<<"steps="<<steps<<endl;
        if (steps <= k) {
            k -= steps;
            curr++;
        } else {
            curr = curr*10;
            k--;
        }
    }
    return curr;
}
int main() {
    //freopen("in.txt","r",stdin);
    cout<<findKthNumber(5000,200)<<endl;
    return 0;
}
复制代码

 

posted @   shiningrise  阅读(24)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2017-03-24 1064: 不明飞行物(ufo)
2017-03-24 支付
// 侧边栏目录 // https://blog-static.cnblogs.com/files/douzujun/marvin.nav.my1502.css
点击右上角即可分享
微信分享提示