蓝桥杯每日一题----第k个数

题目:第k个数
在这里插入图片描述
主要为了学习数字的构造方法,如何快速求1~n中前缀为pre的数字的个数。

题目分析

一开始想的是把数字转化为字符串,然后丢给sort排序就行了,但是n太大了,会出现溢出问题。走到这里也从侧面反映了对所有的数字排序然后输出第k个数字的方法是不可取的,那么可不可以直接构造出第k个数字呢?
首先查找一下以1开头的数字个数,假设是在1~321里面寻找,那么以1开头的数字有1+10+100=111个,如果k=13<111,说明可以确定排序为k的数字的第一位就是1,那么再枚举下一位,下一位枚举以10开头的数字个数(这里1是已经确定的,但是呢1也是以1开头的,在枚举10的时候相当于舍弃了数字1,所以这里要k–,减掉数字1)有1+10=11个,假设k=12>11,那么说明排序为k的数字的第二位不是0,那么按照字典序枚举下一个数字,但是此时,我们可以把以10开头的数字舍弃掉了,所以k-=11,k=1。即查找以11开头的数字的个数有1+10=11个,假设k<11,说明排名为k的数字是以11开头的,然后再找110开头的数字的个数是1个,刚好和k相等,说明我已经找到那个数字了,就是110。
我们自己按照字典序排一下,看一看是不是,
1,10,101,102,103,104,105,106,107,108,109,11,110
可以看到110刚好排在第13的位置,说明我们上面分析的过程是对的。接下来看一下刚刚那个代码应该怎么写。

 Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();//数据范围为1~nint k = scanner.nextInt();//找字典序排名为第k的数字int cur = 1;//从以数字1开头的数字开始尝试while(k > 0) {long nums = get(n,cur,cur+1);//找以cur开头的数字的个数,具体怎么找后续讨论if(k==nums&&k==1) {//如果k和nums相等或者不相等,但是k=1了,都说明当前的数字cur就是我们要找的数字,System.out.println(cur);return;}if(nums < k) {//当前数字个数小于k,说明不是以cur开头的,就找下一个,即cur+1,同时排除掉以cur开头的数字,所以k-=numcur += 1;k -= nums;}else {//当前数字个数大于k,说明是以cur开头的,那么就令cur*=10,然后再接着找下一位应该是以啥开头,cur*=10说明我们舍弃了cur本身,所以这里k要减1cur *= 10;k -= 1;}}

接下来就是如何求以cur开头的数字个数了

方法一

假设求1~123中以cur=1开头的数字个数,这里再加一个辅助的cur1,cur1=cur+1=2,
数字位数为1位时:cur1-cur=2-1=1;
cur1*=10;cur*=10;
数字位数为2位时:cur1-cur=20-10=10;
cur1*=10;cur*=10;
数字位数为3位时:cur1-cur=200-100=100;(×)
我们达不到200,只能达到123,所以应该是
数字位数为3位时:min(cur1,n+1)-cur=123+1-100=24;
总结:
数字位数为p位时:num+=min(cur1,n+1)-cur;
所以这里的代码为,

private static long get(int n, long cur, long cur1) {// TODO Auto-generated method stublong nums = 0;//统计以cur开头的数字的个数while(cur <= n) {nums += Math.min(n+1, cur1)-cur;cur *= 10;cur1 *= 10;}return nums;
}

方法二

假设求1~123中以cur=1开头的数字个数,
base=cur=1;max=cur=1;
数字位数为1位时:max-base+1=1-1+1=1;
base*=10=10;max=max10+9=19;
数字位数为2位时:max-base+1=19-10+1=10;
base
=10=100;max=max*10+9=199;
数字位数为3位时:max-base=199-100+1=100;(×)
我们达不到200,只能达到123,所以应该是
数字位数为3位时:min(max,n)-base+1=123-100+1=24;
总结:
数字位数为p位时:num+=min(max,n)-base+1;
所以这里的代码为,

private static long get2(int n, long cur) {//13 1// TODO Auto-generated method stublong nums = 0;//统计以cur开头的数字的个数long base = cur;//19 13-10+1long max = cur;//10while(base <= n) {nums += Math.min(n, max)-base+1;max =max * 10+9;//和base位数相同但是是该位数下以cur开头的最大的数字base *= 10;}return nums;
}

全部代码

import java.util.Scanner;public class Main{
public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();int k = scanner.nextInt();int cur = 1;
//    k--;while(k > 0) {
//        long nums = get(n,cur,cur+1);long nums = get2(n,cur);if(k==nums&&k==1) {System.out.println(cur);return;}
//        System.out.println(cur + " " + nums);if(nums < k) {//当前字符个数小于kcur += 1;k -= nums;}else {cur *= 10;k -= 1;}}System.out.println(cur);
}private static long get(int n, long cur, long cur1) {// TODO Auto-generated method stublong nums = 0;//统计以cur开头的数字的个数while(cur <= n) {nums += Math.min(n+1, cur1)-cur;cur *= 10;cur1 *= 10;}return nums;
}private static long get2(int n, long cur) {//13 1// TODO Auto-generated method stublong nums = 0;//统计以cur开头的数字的个数long base = cur;//19 13-10+1long max = cur;//10while(base <= n) {nums += Math.min(n, max)-base+1;max =max * 10+9;//和base位数相同但是是该位数下以cur开头的最大的数字base *= 10;}return nums;
}
}

测试结果
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

金和OA jc6 UploadFileBlock 任意文件上传漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

2024美国大学生数学建模E题财产保险的可持续模型详解思路+具体代码季节性时序预测SARIMA天气预测建模

上一篇已经对赛题进行详细分析了&#xff0c;而且大方向和基本的模型已经确定完毕&#xff0c;数据集都已经找到了&#xff0c;现在最重要的就是要分析风暴数据集以及建立时序预测模型&#xff0c;使用气候模型预测的数据&#xff0c;评估气候变化对未来极端天气事件频率和强度…

Acwing 141 周赛 解题报告 | 珂学家 | 逆序数+奇偶性分析

前言 整体评价 很普通的一场比赛&#xff0c;t2思维题&#xff0c;初做时愣了下&#xff0c;幸好反应过来了。t3猜猜乐&#xff0c;感觉和逆序数有关&#xff0c;和奇偶性有关。不过要注意int溢出。 欢迎关注: 珂朵莉的天空之城 A. 客人数量 题型: 签到 累加和即可 import…

机器学习 | 如何利用集成学习提高机器学习的性能?

目录 初识集成学习 Bagging与随机森林 Otto Group Product(实操) Boosting集成原理 初识集成学习 集成学习&#xff08;Ensemble Learning&#xff09;是一种通过组合多个基本模型来提高预测准确性和泛化能力的机器学习方法。它通过将多个模型的预测结果进行整合或投票来做…

[Python] 什么是网格搜索以及scikit-learn中GridSearch类的介绍和使用案例?

什么是网格搜索&#xff1f; 网格搜索是一种参数调优的方法&#xff0c;它可以帮助找到最佳的模型参数。在网格搜索中&#xff0c;我们先指定参数的候选值范围&#xff0c;然后枚举所有可能的参数组合&#xff0c;计算每个模型的性能指标&#xff08;比如准确率、精确率等&…

Compose | UI组件(十二) | Lazy Layout - 列表

文章目录 前言LazyListScope作用域 用来干什么&#xff1f;LazyColumn组件含义&#xff1f;LazyColumn的基本使用LazyColumn Padding设置边距LazyColumn 设置边距 (contentPadding)LazyColumn 为每个子项设置边距 (Arrangement.spacedBy())LazyColumn 根据 rememberLazyListSta…

如何在centos云服务器上持续运行

一、直接上命令 cd到jar包所在目录 输入命令运行 nohup java -jar xxx.jar & 退出当前命令 二、云服务器上安装宝塔管理面板 直接用宝塔的进程守护&#xff0c;设置好当前进程输入参数保存就ok

大规模机器学习简介

1. 非线性回归问题 1.1 问题描述 我们有一组实验数据&#xff0c;每个实验都给出了输入和输出对 (Xn, Yn)。每个输入 是空间中的一个点&#xff0c;每个输出 是 空间中的一个点。这些数据点被假设为独立同分布&#xff08;i.i.d&#xff09;。 我们的目标是找到一个函数 fw&…

智慧商城(continue)

文章目录 1.静态页面结构准备和动态渲染2.搜索 - 历史记录管理1. 写好基础静态页面,可以先往里面加一点假数据2. 上面基本的渲染直接利用history渲染就可以了3. 搜索历史基本渲染结束了,开始点击搜索添加历史4. vant内用v-model" ",可以快速拿到搜索框的值5. 往历史记…

2024年美国大学生数学建模比赛MCM问题B:搜索潜水器-思路解析与代码解答

2024 MCM Problem B Searching for Submersibles 一、题目翻译 背景&#xff1a; 总部位于希腊的小型海上巡航潜艇&#xff08;MCMS&#xff09;公司&#xff0c;制造能够将人类运送到海洋最深处的潜水器。潜水器被移动到该位置&#xff0c;并不受主船的束缚。MCMS现在希望用…

IP地址查询网络威胁:解析威胁、防范攻击

随着互联网的不断普及和发展&#xff0c;网络威胁也愈发严峻。对IP地址进行查询以解析网络威胁&#xff0c;成为网络安全领域一项重要的工作。本文将深入探讨IP地址查询网络威胁的原理、应用场景、防范策略以及未来的发展方向。 IP地址查询网络威胁原理 IP地址查询IP数据云 -…

【Java程序设计】【C00243】基于Springboot的社区医院管理系统(有论文)

基于Springboot的社区医院管理系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的社区医院管理服务系统 本系统分为系统功能模块、管理员功能模块、用户功能模块以及医生功能模块。 系统功能模块&#xff1a;社…