【计蒜客信息学模拟赛1月月赛 - D】Wish(dp计数,数位)

题干:

如果一个数大于等于 10且任意连续两位都是质数,那么就称之为 Wish 数。当然,第一个 Wish 数是 11。

比如 97,111,131,119 都是 Wish 数,而 12,136 则不是。

问第 N 个 Wish 数是多少。

输入格式

一个整数 NN。

输出格式

一个 Wish 数。

数据范围

对于 30\%30% 的数据:1 \le N \le 211≤N≤21。

对于 60\%60% 的数据:1 \le N \le 10001≤N≤1000。

对于 100\%100% 的数据:1 \le N \le 97979797979797971≤N≤9797979797979797。

输出时每行末尾的多余空格,不影响答案正确性

样例输入复制

1

样例输出复制

11

解题报告:

思路:预处理一下  1 -  9 每个数后面可以跟的能够与它组成两位数字并且为素数的数字。

dp[ i ] [ j ]  i 的含义是 i 长度为i 的数字,开头为 j 的 wish 数,那么他就可以由 dp [ i - 1] [ 预处理的 g[ j ]  ]转移而来,注意处理边界,也就是i==2的情况。

需要f [ i ]存储的是 长度为 i 的Wish总数 ,最后根据res去具体定位那个数是个几位数(也就是看还剩下多少数可以放)。然后从 高位开始确定每一位数字是什么,枚举每一位数字时候从小到大。。这也是为什么预处理的时候需要两层循环,而非10~99这样,就是因为这个顺序问题。

AC代码:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<queue>
#include<map>
#include<vector>
#include<set>
#include<string>
#include<cmath>
#include<cstring>
#define ll long long
#define pb push_back
#define pm make_pair
#define fi first
#define se second
using namespace std;
const int MAX = 2e6 + 5;
ll dp[45][10],f[45];//dp[i][j] : i位整数以j这个数字开头 
vector<int> vv[11];
ll n,sum;
string ans;
bool is(int x) {if(x<2) return 0 ;for(int i = 2; i*i<=x; i++) {if(x%i == 0) return 0 ;}return 1;
}
int main()
{for(int i = 0; i<10; i++) {for(int j = 0; j<10; j++) {if(is(i*10 + j)) vv[i].pb(j);}}for(int j = 1; j<10; j++) vv[10].pb(j); //for(int j = 1; j<10; j++) dp[2][j]=1;//f[2] = for(int i = 2; i<=40; i++) {for(int j = 1; j<10; j++) {int up = vv[j].size();for(int k = 0; k<up; k++) {int x = vv[j][k];if(i == 2) dp[i][j]++;else dp[i][j] +=dp[i-1][x] ;}f[i] += dp[i][j];}}cin>>n;int i=2;while(sum + f[i] < n) sum += f[i],i++;ll res = n;res -= sum;int x = 10;//枚举首位 for(;i>=2; i--) {int up = vv[x].size();for(int k = 0; k<up; k++) {int j = vv[x][k];if(res - dp[i][j] > 0 ) res -= dp[i][j]; else {ans.pb('0'+j);x=j;break;} }}ans.pb('0'+vv[x][res-1]);cout << ans << endl;return 0 ;}

 

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

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

相关文章

mysql8 授权远程登录_MySQL8 远程授权访问

在测试环境&#xff0c;想实现MySQL 8 数据库的远程访问授权。传统的方法已经不行&#xff0c;报1064错误GRANT ALL PRIVILEGES ON *.* TO root% IDENTIFIED BY 123456 WITH GRANT OPTION;ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that co…

【计蒜客信息学模拟赛1月月赛 - B】蒜头套圈圈(贪心,前缀最大值)

题干&#xff1a; 蒜头去嘉年华玩儿套圈圈&#xff0c;是这么玩儿的。有一些瓶口口径不同的啤酒瓶&#xff0c;瓶子里面有一些奖品。如果蒜头用手上的圈圈套中了啤酒瓶&#xff0c;那么奖品就归他了。 假设蒜头君无限精准&#xff0c;指哪儿打哪儿&#xff0c;并且蒜头了解到…

centos web 访问mysql_Centos7安装Web服务器--Mysql5.7.12安装

我是勤劳的搬运工……源码装了好多次Mysql&#xff0c;终于成功了……因为安装mysql需要对应的boost文件(必须是相应版本&#xff0c;不能高也不能低)&#xff0c;所以&#xff0c;为了不再麻烦的搜索对应的boost文件&#xff0c;下载包含boost的Mysql包2.查看是否有编译器# gc…

【计蒜客 - 蓝桥训练】轻重搭配(贪心,STLset 或 二分)

题干&#xff1a; n 个同学去动物园参观&#xff0c;原本每人都需要买一张门票&#xff0c;但售票处推出了一个优惠活动&#xff0c;一个体重为 xx 的人可以和体重至少为 2x2x 配对&#xff0c;这样两人只需买一张票。现在给出了 nn 个人的体重&#xff0c;请你计算他们最少需…

phpstudy mysql5.1_linux下mysql5.1 和 5.7安装教程详解

本文主要和大家分享linux下mysql 5.1 和 5.7的安装教程&#xff0c;希望能帮助到大家。以下内容的操作系统为&#xff1a;centos 6.7yum安装mysql 5.1.73卸载系统自带的mysql执行以下命令查看是否有自带mysql:rpm -qa | grep mysql如果发现有输出结果,那么执行以下命令依次删除…

【牛客 - 368C】流星雨(概率dp,乘法逆元)

题干&#xff1a; 现在一共有n天&#xff0c;第i天如果有流星雨的话&#xff0c;会有wiwi颗流星雨。 第i天有流星雨的概率是pipi。 如果第一天有流星雨了&#xff0c;那么第二天有流星雨的可能性是p2Pp2P&#xff0c;否则是p2p2。相应的&#xff0c;如果第i−1 (i≥2)i−1 (…

mysql workbench 无法编辑_MySQL Workbench编辑表数据是只读的

14 个答案:答案 0 :(得分&#xff1a;60)我假设桌子有一把主键。首先尝试运行unlock tables命令以查看是否修复了它。如果所有其他方法都失败了&#xff0c;您可以更改表以创建具有自动增量的新主键列&#xff0c;并希望能够修复它。一旦完成&#xff0c;您应该能够毫无问题地删…

【计蒜客 - 蓝桥训练】炮台实验(数学期望,期望dp)

题干&#xff1a; 蒜头君在玩一个战争模拟游戏&#xff0c;他有高度为 1,2,3,\ldots ,n1,2,3,…,n 的炮台各一个&#xff0c;他需要把这 nn 个炮台从左往右排成一行&#xff0c;并且炮口都朝向右边。 在这个游戏中&#xff0c;所有炮台发射的炮弹会摧毁前方所有高度比自己低的…

mysql本身主从_Mysql主从复制

Mysql环境准备#下载Mysqlwget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm如果报错: -bash: wget: 未找到命令安装插件 yum -y install wget安装mysql-community-release-el7-5.noarch.rpmsudo rpm -ivh mysql-community-release-el7-5.noarch.rpm安装Mys…

【蓝桥杯官网试题 - 算法提高 】P0404(模拟)

题干&#xff1a; 计算一个无符号整数的阿尔法乘积。对于一个无符号整数x来说&#xff0c;它的阿尔法乘积是这样来计算的&#xff1a;如果x是一个个位数&#xff0c;那么它的阿尔法乘积就是它本身&#xff1b;否则的话&#xff0c;x的阿尔法乘积就等于它的各位非0的数字相乘所…

phison主控ps3111量产工具_从固态硬盘拆解看门道 深入解读闪存编号和主控容量...

一篇固态硬盘的评测是否有水平&#xff0c;不光是看测试跑分是否详细&#xff0c;更应有针对成绩的解读以及硬件拆解和结构上的分析。毕竟跑分大家都会跑&#xff0c;必须拿出其他人不知道的内存才能真正吸引读者。因为大多数固态硬盘拆解会失去保修&#xff0c;所以拆解是网友…

*【计蒜客 - 蓝桥训练】人以群分(二分 + dp)

题干&#xff1a; 某班有 nn 个同学&#xff0c;每个同学有一个外向程度 a_iai​。由于要进行某个活动&#xff0c;需要把他们分成若干个小组&#xff0c;每个小组的人数至少为 mm 人。不同外向程度的人在一个小组会产生不开心值&#xff0c;定义一个小组的不开心值为组内成员…

alot英文怎么读_【乐学】“原来如此”用英文怎么说?

英语中的“原来如此”则有几种不同的表达下面就让我们一起来看看吧&#xff01;I seeI see 作为最地道的表达&#xff0c;使用起来准没错。这是来自《柯林斯词典》的释义&#xff1a;You can say "I see" to indicate that you understand what someone is telling y…

【牛客 - 318E】爱摸鱼的Dillonh(数学,暴力,细节)

题干&#xff1a; “我不做人啦&#xff0c;jojo&#xff01;” “Dillonh起来回答问题&#xff01;” “啊&#xff1f;”沉迷于jojo的Dillonh又一次上课摸鱼被老师抓到了&#xff0c;他慌忙地抬起头看着讲台上火冒三丈的老师。 “给你一个数n&#xff0c;现在要找到一个集…

特殊mac地址文档_Mac颜值秒杀Win10?五款神器让Win10化身macOS

微软在Win10上捣鼓已经不是一天两天了&#xff0c;可结果……还是难以令人满意&#xff0c;特别是不伦不类的UI&#xff01;其实Win10的底子还是不错的&#xff0c;新技术用了不少&#xff0c;外观也比之前更有颜值&#xff0c;但……总感觉缺了点什么&#xff01;有没有羡慕隔…

【hihocoder - offer编程练习赛60 A】hohahola(贪心,二分)

题干&#xff1a; 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 有一种叫作hohahola的饮料&#xff0c;售价是X元一瓶。小Hi非常喜欢这种饮料&#xff0c;但是他现在身无分文。 不过小Hi有N张优惠券&#xff0c;买hohahola时每瓶最多使用一张优惠券&#xff0c…

checkbox设置三种状态 qt_checkbox的三种状态处理

checkbox只有两种值&#xff1a;选中(checked)或未选中(unchecked)。它可以有任何值&#xff0c;但是表单提交时checkbox的值只能是checked或unchecked。它的默认值是unchecked&#xff0c;你可以在HTML中这样控制它&#xff1a;视觉上&#xff0c;checkbox有三种状态&#xff…

【hihocoder - offer编程练习赛60 B】最大顺子(双指针,思维)

题干&#xff1a; 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 你有N张卡片&#xff0c;每张卡片上写着一个正整数Ai&#xff0c;并且N张卡片上的整数各不相同。 此外&#xff0c;你还有M张百搭卡片&#xff0c;可以当作写着任意正整数的卡片。 一个“顺子…

drupal mysql_Drupal MySQL查询优化

我试图优化一个MySQL查询来加速Drupal视图。这些表是节点&#xff0c;term_node和term_data。节点有大约500k行&#xff0c;term_node大约800k&#xff0c;term_data大约300k。查询下方&#xff1a;SELECT SQL_NO_CACHE DISTINCT(node.nid) AS nidFROM drupal_node nodeLEFT JO…

raft算法mysql主从复制_Etcd raft算法实现原理分析

1.1 主要概念要实现集群数据的一致性&#xff0c;节点在进行通信的时候必定需要遵守特定规则进行数据校验&#xff0c;而这些规则具体都是通过某些具有特定含义的属性来实现的。为了让对Raft 算法比较陌生的读者对算法的关键概念有一个初步认识&#xff0c;作者整理了算法中涉及…