题目链接

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。


  1. #include<bits/stdc++.h>
  2. #include<math.h>
  3. using namespace std;
  4. int main()
  5. {
  6. long long k, m, i = 0, j, l = 0, a[30], b = 0, d, c, e, n = 0, aa = 0, bb;
  7. cin >> k; //输入k
  8. cin >> m; //输入m
  9. c = k; //将k赋给c,不让k变化
  10. while (c) //将k存到数组a[]里
  11. {
  12. a[i] = c % 10;
  13. c = c / 10;
  14. i++;
  15. }
  16. b = 0;
  17. e = i;
  18. d = e;
  19. for (d; n <= i + 1; d--)
  20. {
  21. for (j = 1; j <= d; j++)
  22. {
  23. l = pow(10, j - 1) + l;
  24. }
  25. if (n == 0)
  26. b = (a[i - 1 - n] - 1)*l + b;
  27. else
  28. b = a[i - 1 - n] * l + b;
  29. n++;
  30. l = 0;
  31. }
  32. b = b + i;//最小值为k时,k的排名
  33. if (b == m) {
  34. cout << k;
  35. }
  36. else if (m < b) { cout << 0; }
  37. else
  38. for (e = i;;e++)
  39. {
  40. bb = k * pow(10, e - i + 1) - pow(10, e) + aa;
  41. if (m - b <= bb)
  42. {
  43. cout << setprecision(30) << m - b - 1 - aa + pow(10, e);
  44. break;
  45. }
  46. aa = k * pow(10, e - i + 1) - pow(10, e) + aa;
  47. }
  48. return 0;
  49. }

  

方法

先考虑当最大的整数为k时,k的位置。 代码如下:

  1. for (d; n <= i + ; d--)
  2. {
  3. for (j = ; j <= d; j++)
  4. {
  5. l = pow(, j - ) + l;
  6. }
  7. if (n == )
  8. b = (a[i - - n] - )*l + b;
  9. else
  10. b = a[i - - n] * l + b;
  11. n++;
  12. l = ;
  13. }
  14. 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

数字的数量 用代码表示为

  1. *pow(,-+)-pow(,)
  2. //pow(10,4-3+1)中的4代表4位数
  3. 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 有趣的数】 题解的更多相关文章

  1. 洛谷 P2022 有趣的数 解题报告

    P2022 有趣的数 题目描述 让我们来考虑1到N的正整数集合.让我们把集合中的元素按照字典序排列,例如当N=11时,其顺序应该为:1,10,11,2,3,4,5,6,7,8,9. 定义K在N个数中的 ...

  2. C++ 洛谷 P2657 [SCOI2009]windy数 题解

    P2657 [SCOI2009]windy数 同步数位DP 这题还是很简单的啦(差点没做出来 个位打表大佬请离开(包括记搜),我这里讲的是DP!!! 首先Cal(b+1)-Cal(a),大家都懂吧(算 ...

  3. 洛谷 P1004 方格取数 题解

    P1004 方格取数 题目描述 设有 \(N \times N\) 的方格图 \((N \le 9)\),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字\(0\).如下图所示(见样例): ...

  4. 洛谷P2657 [SCOI2009]windy数 题解 数位DP

    题目链接:https://www.luogu.com.cn/problem/P2657 题目大意:找区间 \([A,B]\) 范围内 不含前导零 且 相邻两个数字之差至少为2 的正整数的个数. 题目分 ...

  5. P2022 有趣的数

    P2022 有趣的数 题目描述 让我们来考虑1到N的正整数集合.让我们把集合中的元素按照字典序排列,例如当N=11时,其顺序应该为:1,10,11,2,3,4,5,6,7,8,9. 定义K在N个数中的 ...

  6. 洛谷P1783 海滩防御 分析+题解代码

    洛谷P1783 海滩防御 分析+题解代码 题目描述: WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和 ...

  7. 洛谷P4047 [JSOI2010]部落划分题解

    洛谷P4047 [JSOI2010]部落划分题解 题目描述 聪聪研究发现,荒岛野人总是过着群居的生活,但是,并不是整个荒岛上的所有野人都属于同一个部落,野人们总是拉帮结派形成属于自己的部落,不同的部落 ...

  8. 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)

    洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...

  9. 【洛谷P2022】有趣的数

    有趣的数 题目链接 首先求出1~k中有多少个在k前面的数的个数,若>m,则无解 比如12345,从第一位开始, 1 0~1 共2个 1-0+1 12  10~12共3个    12-10+1 1 ...

  10. 洛谷10月月赛II题解

    [咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...

随机推荐

  1. 《Python学习手册 第五版》 -第2章 Python如何运行程序

    第二章主要讲解了Python的运行机制, 在开始之前,需要明确以下几点 因为<Python学习手册>这本书是面向市场很多人的,既然有很多人,就有很多不一样的需求和使用情况,这本书涵盖Pyt ...

  2. 题解 bzoj1954【Pku3764 The xor – longest Path】

    做该题之前,至少要先会做这道题. 记 \(d[u]\) 表示 \(1\) 到 \(u\) 简单路径的异或和,该数组可以通过一次遍历求得. \(~\) 考虑 \(u\) 到 \(v\) 简单路径的异或和 ...

  3. 题解 bzoj3688【折线统计】

    考虑 \(dp\) . 首先把所有节点按 \(x\) 从小到大排序是很有必要的. 记 f[i][j][0] 表示满足以第 \(i\) 个节点做折线结尾,选取的点集 \(S\) 满足 \(f(S)=j\ ...

  4. Rust入坑指南:步步为营

    俗话说:"测试写得好,奖金少不了." 有经验的开发人员通常会通过单元测试来保证代码基本逻辑的正确性.如果你是一名新手开发者,并且还没体会到单元测试的好处,那么建议你先读一下我之前的 ...

  5. 《Head first设计模式》之迭代器模式

    迭代器模式提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露其内部的表示. 爆炸性新闻:对象村餐厅和对象村煎饼屋合并了! 真是个好消息!现在我们可以在同一个地方,享用煎饼屋美味的煎饼早餐,和好吃 ...

  6. Solr搜索解析及查询解析器用法概述

    一.简介 大多数查询都使用 了标准的Solr语法.这种语法是Solr最常见的,由默认查询解析器负责处理.Solr的默认查询解析器是Lucene查询解析器[LuceneQParserPlugin类实现] ...

  7. qt creator源码全方面分析(2-8)

    目录 Editing MIME Types Editing MIME Types Qt Creator使用文件的MIME类型,来确定用于打开文件的模式和编辑器. 例如,Qt Creator在C++编辑 ...

  8. zabbix的mysql优化后的配置文件

    zabbix的mysql数据库导致磁盘IO一直90%以上,访问卡的一逼 改了配置文件最后好了 [root@root /]# cat /etc/my.cnf [mysqld] datadir=/Data ...

  9. SpringBoot基础篇-SpringBoot快速入门

    SpringBoot基础 学习目标: 能够理解Spring的优缺点 能够理解SpringBoot的特点 能够理解SpringBoot的核心功能 能够搭建SpringBoot的环境 能够完成applic ...

  10. SHELL下打包文件

    SHELL下打包文件 在我们拿下webshell的时候,想要获取数据或者源码往往会用菜刀或者蚁剑去打包,但是这个时候往往就会出现很多问题,列如打包失败,或者是打包得不完整等等. 这个时候如果对方是wi ...