洛谷【P2022 有趣的数】 题解
题目链接
https://www.luogu.org/problem/P2022
题目描述
让我们来考虑1到N的正整数集合。让我们把集合中的元素按照字典序排列,例如当N=11时,其顺序应该为:1,10,11,2,3,4,5,6,7,8,9。
定义K在N个数中的位置为Q(N,K),例如Q(11,2)=4。现在给出整数K和M,要求找到最小的N,使得Q(N,K)=M。
输入格式
输入文件只有一行,是两个整数K和M。
输出格式
输出文件只有一行,是最小的N,如果不存在这样的N就输出0。
#include<bits/stdc++.h>
#include<math.h>
using namespace std;
int main()
{
long long k, m, i = 0, j, l = 0, a[30], b = 0, d, c, e, n = 0, aa = 0, bb;
cin >> k; //输入k
cin >> m; //输入m
c = k; //将k赋给c,不让k变化
while (c) //将k存到数组a[]里
{
a[i] = c % 10;
c = c / 10;
i++;
}
b = 0;
e = i;
d = e;
for (d; n <= i + 1; d--)
{
for (j = 1; j <= d; j++)
{
l = pow(10, j - 1) + l;
}
if (n == 0)
b = (a[i - 1 - n] - 1)*l + b;
else
b = a[i - 1 - n] * l + b;
n++;
l = 0;
}
b = b + i;//最小值为k时,k的排名
if (b == m) {
cout << k;
}
else if (m < b) { cout << 0; }
else
for (e = i;;e++)
{
bb = k * pow(10, e - i + 1) - pow(10, e) + aa;
if (m - b <= bb)
{
cout << setprecision(30) << m - b - 1 - aa + pow(10, e);
break;
}
aa = k * pow(10, e - i + 1) - pow(10, e) + aa;
}
return 0;
}
方法
先考虑当最大的整数为k时,k的位置。 代码如下:
for (d; n <= i + ; d--)
{
for (j = ; j <= d; j++)
{
l = pow(, j - ) + l;
}
if (n == )
b = (a[i - - n] - )*l + b;
else
b = a[i - - n] * l + b;
n++;
l = ;
}
b = b + i;//最小值为k时,k的排名
其中数组a[ ]里存着k
这段代码的讲解如下,为方便理解,令k=453,则有四种数字在k前边:
- (1)首位以1、2、3开头的数字,个数为(1+10+100)×(4-1)
- (2)首位为4的数,次位小于5的数,个数为(1+10)×(5-0)+1
- (3)首位为4,次位为5,第3位小于3的数,个数为1×(3-0)
- (4)首位或第二位与K相同,但总位数小于k。两个,分别为4、45
通过这种方法就求出来了最大值为k时的排名b。
- 如果m=b,那显然最小值n=k;
- 如果m<b,则不存在n,因为该组数的最小值肯定是>=k的。
- 如果m>b,则一定存在n。
下面讨论m>b的情况。
分析易知,若m>b,则n的位数肯定大于k的位数。K=453有3位,分析知4位数里排在453前边的数字有:
- 1000-1999,2000-2999,3000-3000,4000-4529
数字的数量 用代码表示为
*pow(,-+)-pow(,)
//pow(10,4-3+1)中的4代表4位数
3代表K的位数,pow(,)里的4代表4位数
若
- (m-3位数字中k的排名)<4位数里排在453前边的数字个数时
- 则所求数字n必然为四位数字,且n在1000-1999,2000-2999,3000-3000,4000-4529范围内
- n=(m-3位数字中k的排名-1)+1000。 若
- (m-3位数字中k的排名)>4位数里排在453前边的数字个数,则应继续判断(m-4位数字中k的排名)与5位数里排在453前边的数字个数大小,直到 (m-i位数字中453的排名)<与(i+1)位数里排在453前的数字量,此时即可得到所求的最小数字
- n=(m-i位数字中453的排名-1)+pow(10, i);
以上就是这道题的题解
洛谷【P2022 有趣的数】 题解的更多相关文章
- 洛谷 P2022 有趣的数 解题报告
P2022 有趣的数 题目描述 让我们来考虑1到N的正整数集合.让我们把集合中的元素按照字典序排列,例如当N=11时,其顺序应该为:1,10,11,2,3,4,5,6,7,8,9. 定义K在N个数中的 ...
- C++ 洛谷 P2657 [SCOI2009]windy数 题解
P2657 [SCOI2009]windy数 同步数位DP 这题还是很简单的啦(差点没做出来 个位打表大佬请离开(包括记搜),我这里讲的是DP!!! 首先Cal(b+1)-Cal(a),大家都懂吧(算 ...
- 洛谷 P1004 方格取数 题解
P1004 方格取数 题目描述 设有 \(N \times N\) 的方格图 \((N \le 9)\),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字\(0\).如下图所示(见样例): ...
- 洛谷P2657 [SCOI2009]windy数 题解 数位DP
题目链接:https://www.luogu.com.cn/problem/P2657 题目大意:找区间 \([A,B]\) 范围内 不含前导零 且 相邻两个数字之差至少为2 的正整数的个数. 题目分 ...
- P2022 有趣的数
P2022 有趣的数 题目描述 让我们来考虑1到N的正整数集合.让我们把集合中的元素按照字典序排列,例如当N=11时,其顺序应该为:1,10,11,2,3,4,5,6,7,8,9. 定义K在N个数中的 ...
- 洛谷P1783 海滩防御 分析+题解代码
洛谷P1783 海滩防御 分析+题解代码 题目描述: WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和 ...
- 洛谷P4047 [JSOI2010]部落划分题解
洛谷P4047 [JSOI2010]部落划分题解 题目描述 聪聪研究发现,荒岛野人总是过着群居的生活,但是,并不是整个荒岛上的所有野人都属于同一个部落,野人们总是拉帮结派形成属于自己的部落,不同的部落 ...
- 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)
洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...
- 【洛谷P2022】有趣的数
有趣的数 题目链接 首先求出1~k中有多少个在k前面的数的个数,若>m,则无解 比如12345,从第一位开始, 1 0~1 共2个 1-0+1 12 10~12共3个 12-10+1 1 ...
- 洛谷10月月赛II题解
[咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...
随机推荐
- js 浏览器兼容问题及解决办法
JS中出现的兼容性问题的总结 1.关于获取行外样式 currentStyle 和 getComputedStyle 出现的兼容性问题 我们都知道js通过style不可以获取行外样式,当我们需要获取行 ...
- 编写SQL语句(快速回顾)
注:源自于<Java程序员面试秘笈>! 1.创建数据库MYDB create database MYDB 2.创建学生表student (sno,sname,ssex,sage,sclas ...
- 磁盘文件系统管理与LVM逻辑卷
一.磁盘以及分区管理 无论是Linux系统还是Windows系统.当现有硬盘的规划不能满足当前需求时.我们就需要将其重新规划和调整 实现上述操作我们就需要用到fdisk磁盘及分区管理工具.此工具是大多 ...
- 如何用Python实现do...while语句
我在编程的时候可能会遇到如下代码: a = 0 while a != 0: a = input() print a 我所设想的运行过程是这样的: 很显然我是想先运行后判断的模式,即 do...whil ...
- OpenCV图像变换二 投影变换与极坐标变换实现圆形图像修正
投影变换 在放射变换中,物体是在二维空间中变换的.如果物体在三维空间中发生了旋转,那么这种变换就成为投影变换,在投影变换中就会出现阴影或者遮挡,我们可以运用二维投影对三维投影变换进行模块化,来处理阴影 ...
- Windwos日志分析
Windows日志分析工具 查看系统日志方法: 在“开始”菜单上,依次指向“所有程序”.“管理工具”,然后单击“事件查看器” 按 "Window+R",输入 ”eventvwr.m ...
- Flutter Widgets 之 FutureBuilder
注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 展示异步任务状态 当有一个Future(异步)任务需要展示 ...
- mysql出现 Unknown column 'Password' in 'field list'
linux安装了mysql之后初始化密码获取:出现了下面的内容,密码很尴尬,无法用root登录: grep 'temporary password' /var/log/mysqld.log [Note ...
- 【大白话系列】MySQL 学习总结 之 COMPACT 行格式的设计原理
如果大家对我的 [大白话系列]MySQL 学习总结系列 感兴趣的话,可以点击关注一波. 一.回顾 MySQL 学习总结系列至此已经第七节了. 从大方向:我们已经学习了 MySQL 的架构设计.Inno ...
- Nginx之常用基本配置
上一篇博客我们大概介绍了一下nginx,nginx的架构,nginx编译安装和nginx命令的用法,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/1236680 ...