稀碎从零算法笔记Day35-LeetCode:字典序的第K小数字

news2024/11/24 0:47:09

要考虑完结《稀碎从零》系列了哈哈哈

这道题和【LC.42 接雨水】,我愿称之为【笔试界的颜良&文丑】

题型:字典树、前缀获取、数组、树的先序遍历

链接:440. 字典序的第K小数字 - 力扣(LeetCode)

来源:LeetCode

题目描述(红字为笔者添加)

这道题说实话,看不懂是其hard的很大一个原因

给定整数 n 和 k,返回  [1, n] 中字典序第 k 小的数字。

这边笔者解释下什么是字典序

440. 字典序的第K小数字 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/k-th-smallest-in-lexicographical-order/solutions/1358635/zi-dian-xu-de-di-kxiao-shu-zi-by-leetcod-bfy0/

笔者的理解是:【字典序】重点在上,那么作为一个【排序方式】,它的法则即使”按照数字的前缀的大小、长度进行排序“(例子:1,10,100,101,102,11,2……11在101前面,因为11的前缀是”1“,而101前缀是”10“,因此101在11前面;2前缀(虽然没有前缀吧)是2,比1大,因此凡是2打头的,都排在1打头的后面)

题目样例

示例 1:

输入: n = 13, k = 2
输出: 10
解释: 字典序的排列是 [1, 10, 11, 12, 13, 2, 3, 4, 5, 6, 7, 8, 9],所以第二小的数字是 10。

示例 2:

输入: n = 1, k = 1
输出: 1

提示:

  • 1 <= k <= n <= 109

题目思路

笔者的思路来自LC宫水三叶(他的题解有点难看懂,但好在最后还是看懂了,需要有不错的code经验和思路)

LC宫水三叶题解icon-default.png?t=N7T8https://leetcode.cn/problems/k-th-smallest-in-lexicographical-order/solutions/1360662/by-ac_oier-m3zl/

这道题第一个难点,就是知道他是怎么排序的
配合题目描述那里的”十叉树“ ,不难可以看出,遍历方式是”十叉树的先序遍历“,那么本题就是【返回十叉树的先序遍历的第K个数】——>通关了(bushi)

这种方法固然可行,但本题只给了k和n(右边界),创一个不熟悉的数据结构(二叉树笔者都不是很熟悉)不为明智之举。

但这个思路还是很重要的突破口,这时候可以转换一个这个遍历方式:起点是1,1遍历的方向只有【下】和【左】,且以后的节点也是如此。”1向左走“需要满足1这个树下面,没有其他的分支,连10都不能有,这就要求n是小于10的。而”1向下走“,就需要1有”孩子节点“,即以1为前缀的一众节点

那么问题,就可以转化为”看看第k个数是以谁为前缀的?“这个问题。而这个问题,难点就是”求出以各个数为前缀的数的个数“,然后看看k是否在这个范围内:①k在的话,那么k-1,i*10(k-1是跳过i这个数,i*10是i后面的第一个数,即使 i0 )。②k不在,即k>num的话,说明以 i 为前缀的所有数都不满足条件,那么i+1(相当于从1走向2),k-num。③如果k = num,说明第k个数就是最后一个以 i 为前缀的数(这种情况可以归于情况①)

然后就是”求满足条件的数的个数“:举个例子比较直观——比如说n是12345,要求以122为前缀的数的个数。那么截取12345的前3位【123】。以122为前缀的数中,1220—1229是一定<12345的,因此ans+=10。而122又是小于123的,那么说明,所有122为前缀的数都满足条件,即ans+=pow(10,2).。
以上例子是122<123的情况,假如是125>123,那么满足条件的只能是125X系列,即10个
                                              假如是 123 == 123,那么满足条件的除了123X系列,还有【12300,12345】这个区间内的

C++代码

参考三叶思路的CPP coding

class Solution {
public:
    int findKthNumber(int n, int k) {
    //题目需求:返回第K小的数字,排序是按照:前缀越小,越靠前 
    // 三叶的题解 
    int ans = 1;
    while(k > 1)
    {   
        int num = getNum(ans,n);//num是以ans为前缀的数字的个数
        if(num >= k)//第K个数在以ans为前缀的数字中
        {
            ans *=10;
            k--;
        }
        else
        {
            ans ++ ;//以ans为前缀的这一大堆都不行,得换一个前缀
            k-=num;//相当于抛弃了以ans为前缀的那一大堆,从ans+1开始数
        }
    }
    // k == 1,说明1就是答案
    return ans;
    }
    // 获取合法前缀的数字个数
    int getNum(int ans,int n)
    {
        string temp1 = to_string(ans),temp2 = to_string(n);
        int len1 = temp1.length(),len2=temp2.length(),div = len2 - len1;//div表示n比ans多了多少位
        string temp3 = temp2.substr(0,len1);
        int answer = 0;//接收前缀的个数
        int int3 = stoi(temp3);
        // 把位数短的数字的个数先获取出来
        for(int i=0;i<div;i++)
            answer += (int)pow(10,i);//n比ans长的部分
        if(ans < int3)
        {
            answer += (int)pow(10,div);//pow返回double类型
        }
        if(ans == int3)//前缀相等
            answer += n - ans * (int)pow(10,div) + 1;//以1024和10为例子,那么10为前缀的个数是[00-24],工24+1 = 25 个数字;
        return answer;
    }
};

结算页面

 

还需要努力!

你好,四月

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1559710.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Pytorch 下载失败原因

错误信息&#xff1a; ERROR: Could not find a version that satisfies the requirement torch (from versions: none) ERROR: No matching distribution found for torch 解决方案&#xff1a; 在官网看到&#xff0c;它需要python3.8-3.11的环境。过高和过低的版本都不…

番外篇 | 手把手教你如何用YOLOv8实现行人/车辆等过线统计

前言:Hello大家好,我是小哥谈。目标检测行人/车辆等过线统计是一种常见的视频分析任务,用于统计行人/车辆等在指定区域内过线的次数。这个任务通常需要使用目标检测算法来识别行人/车辆等,并使用计数器算法来统计过线的次数。🌈 目录 🚀1.本文介绍 🚀2.实现

LeetCode刷题【链表,图论,回溯】

目录 链表138. 随机链表的复制148. 排序链表146. LRU 缓存 图论200. 岛屿数量994. 腐烂的橘子207. 课程表 回溯 链表 138. 随机链表的复制 给你一个长度为 n 的链表&#xff0c;每个节点包含一个额外增加的随机指针 random &#xff0c;该指针可以指向链表中的任何节点或空节…

2024年泰迪杯数据挖掘B题详细思路代码文章教程

目前b题已全部更新包含详细的代码模型和文章&#xff0c;本文也给出了结果展示和使用模型说明。 同时文章最下方包含详细的视频教学获取方式&#xff0c;手把手保姆级&#xff0c;模型高精度&#xff0c;结果有保障&#xff01; 分析&#xff1a; 本题待解决问题 目标&#…

K8S之Secret的介绍和使用

Secret Secret的介绍Secret的使用通过环境变量引入Secret通过volume挂载Secret Secret的介绍 Secret是一种保护敏感数据的资源对象。例如&#xff1a;密码、token、秘钥等&#xff0c;而不需要把这些敏感数据暴露到镜像或者Pod Spec中。Secret可以以Volume或者环境变量的方式使…

Valkey是一个新兴的开源项目,旨在成为Redis的替代品,背后得到了AWS、Google、Oracle支持

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

金融汽车科技LLM

汇丰银行 众安保险 1. AIGC重塑保险价值链 小额高频 2.构建智能应用的技术方案演进 增加微服务 长记忆&#xff1a;向量库短记忆&#xff1a;对话历史&#xff0c;思考路径&#xff0c;执行历史 中台架构设计 蔚来汽车在大模型的应用实践 公司介绍 应用架构 应用实践 4.大…

每日面经分享(pytest入门)

1. pytest具有什么功能 a. 自动发现和执行测试用例&#xff1a;pytest可以自动发现项目中的测试文件和测试函数&#xff0c;无需手动编写测试套件或测试运行器。 b. 丰富的断言函数&#xff1a;pytest提供了丰富的断言函数&#xff0c;方便地验证测试结果是否符合预期。断言函…

SpringBoot + Vue3邮件验证码功能的实现

后端 SpringBootmavenmysqlIDEA 后端负责编写邮件发送的接口逻辑&#xff0c;具体流程如下: 引入相关依赖配置邮箱信息编写邮件发送服务接口OK 引入依赖 <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-mail --> <dependen…

论文笔记:GEOLLM: EXTRACTING GEOSPATIALKNOWLEDGE FROM LARGE LANGUAGE MODELS

ICLR 2024 reviewer 评分 35668 1 intro 1.1 地理空间预测 地理空间预测在各个领域都有广泛的应用 包括贫困估算&#xff0c;公共卫生&#xff0c;粮食安全&#xff0c;生物多样性保护&#xff0c;环境保护。。。这些预测中使用的变量包括地理坐标、遥感数据、卫星图像、人类…

手机无线投屏到windows11电脑

1 安装无线投影组件 2 电脑端打开允许其他设备投影的开关 3 手机找到投屏选项 4 手机搜索可用设备连接即可 这里的官方文档给的不太好,给了一些让人眼花撩乱的信息,以下是经过整合的有效信息

PHP在线客服系统源码修复版

源码简介 在线客服系统网站源码https://www.888host.cn/330.html 新增消息预知&#xff0c;消息撤回&#xff0c;消息已读未读&#xff0c; 修复需要刷新才能收到消息 修复客户来源地址 修复消息提示音 修复桌面推送提醒 搭建环境 宝塔面板 &#xff0c;Nginx1.16-1.18 …

【A-012】基于SSH的在线学习考试系统

【A-012】基于SSH的在线学习考试系统 开发环境&#xff1a; Eclipse/MyEclipse、Tomcat8、Jdk1.8 数据库&#xff1a; MySQL 适用于&#xff1a; 课程设计&#xff0c;毕业设计&#xff0c;学习等等 系统介绍 有偿

centos7.5安装gitlab-runner,配置CI/CD流水线

一般不建议gitlab-server和gitlab-runner装在同一台服务器 第一步&#xff1a;安装gitlab-runner,最好和gitlab实例版本一致 # 下载官方gitlab-runner安装脚本 curl -L "https://packages.gitlab.com/install/repositories/runner/gitlab-runner/script.rpm.sh" | s…

基于FreeRTOS系统的STM32简易遥控器设计

项目说明 该项目是一个基于FreeRTOS系统的Stm32遥控器设计。使用该项目主要是自己学习FreeRTOS的使用&#xff0c;以及模块化编程的思想。这个项目应该长期会有更新。 项目开源 github:https://github.com/snqx-lqh/Stm32RemoteControl gitee:https://gitee.com/snqx-lqh/S…

canvas画图,画矩形可拖拽移动,可拖拽更改尺寸大小

提示&#xff1a;canvas画图&#xff0c;画矩形&#xff0c;圆形&#xff0c;直线&#xff0c;曲线可拖拽移动 文章目录 前言一、画矩形&#xff0c;圆形&#xff0c;直线&#xff0c;曲线可拖拽移动总结 前言 一、画矩形&#xff0c;圆形&#xff0c;直线&#xff0c;曲线可拖…

Lucene及概念介绍

Lucene及概念介绍 基础概念倒排索引索引合并分析查询语句的构成 基础概念 Document&#xff1a;我们一次查询或更新的载体&#xff0c;对比于实体类 Field&#xff1a;字段&#xff0c;是key-value格式的数据&#xff0c;对比实体类的字段 Item&#xff1a;一个单词&#xff0…

非周期连续函数的傅里叶变换

首先 我们把一个非周期信号扩展成一个周期信号 然后用傅里叶级数展开 也可以得到对应的级数系数 利用周期趋向于无穷大 可以把傅里叶级数展开就变成了一个积分 而神奇的是积分里其实还有一个积分 这样我们就得到了傅里叶变换对 我们把里面的积分成为函数的傅里叶变换 把外面…

Qt主窗口 之:停靠/悬浮窗口(QDockWidget)

一、QDockWidget概述 QDockWidget 是 Qt 中的一个窗口部件&#xff0c;用于创建可停靠的窗口&#xff0c;通常用于构建多文档接口&#xff08;MDI&#xff09;或可定制的用户界面。QDockWidget 允许用户将窗口停靠在应用程序的主窗口周围&#xff0c;或将其拖动到独立的浮动窗…

【千帆杯】K12教育常规赛 北京场线下交流会心得

千帆杯K12教育常规赛 北京场线下交流会心得 ​ 周日有幸参加了 百度智能云千帆AppBuilder北京场线下交流会 ( 活动链接 )&#xff0c;去线下组队创作了 K12教育 相关的智能体。参赛过程中认识了不少大佬与朋友&#xff0c;抱大佬队友的腿&#xff0c;他的 猜成语 应用获得了线…