Online JudgeLuogu-P4222

Label:逆向思维,暴力枚举

题目描述

你需要给一批商品编号,其中每个编号都是一个7位16进制数(由0~9, a-f组成)。为了防止在人工处理时不小心把编号弄错,要求任意两个编号至少有三个位置对应的数字不相同。第一个编号为0000000,第二个编号为不违反上述规定的前提下最小的编号,…,每次分配一个新编号时,总是选择不和前面编号冲突的最小编号(注意编号都是16进制数,可以比较大小)。按此规律,前面若干编号分别是:0000000, 0000111, 0000222, …, 0000fff, 0001012, 0001103,0001230,0001321,0001456,…

输入k,你的任务是求出第k小的编号

输入

第一行为整数k。

输出

输出第k小的编号(字母必须输出小写)。输入保证这个编号存在。

样例

Input

20

Output

0001321

Hint

对于30%的数据,\(k \leq 200\);

对于70%的数据,\(k \leq 10000\);

对于100%的数据,\(k \leq 200000\)。

题解

第一眼以为二分答案,但是发现每个值都依赖于前面的数字。需要依次求解。

30pts:

直接暴力枚举16进制数,检验时,暴力与前面的数比较。

时间复杂度为\(O(Ans+K^2*7)\)。其中从小到大枚举数字共\(Ans\)次,每次检验时与前面的数字一位一位比较。

70pts:

尝试打表找规律,然后你会发现,除了最后两个16进制位规律比较迷之外,剩下的前面5位规律都是显而易见的。所以直接打表后面两个位(如果代码长度限制允许的情况下),可以在O(1)时间内求解。

100pts:

这个数据范围显然如果按刚才的方案去打表不太可行(但这题也有很多其他能够AC的神奇打表+哈希做法)。下面是一种比较简洁的做法:

回到30分做法,显然还是需要依次求解,那就尝试优化后面的比较部分。采用逆向思维,当前数字与前面的数字比较,就算枚举都要O(N),不可做;那就尝试用当前的数,对后面合法/不合法的数字打上标记

原题面:至少要有3个对应位不同,才合法

其实就是:只要存在至少5个对应位相同,就不合法

比较相同显然比比较不同可做很多。对于当前弄到的一个合法数字,我们利用组合,按顺序挑出7个中的5个,将这个 组合\(mark\)了,注意,由于要控制对应位,还得记录下这是\(C_7^5=21\)中的第几个组合。

对应的,当判断当前这个数字合不合法时,也是按顺序挑出7个中的5个,如果被\(mark\)了则表示这个数字不合法;反之如果所有组合都没被\(mark\)过,表示这个数字合法。

综上,每次枚举时都可以在\(C_7^5\)的时间内判断是否合法。

代码如下:

#include<bits/stdc++.h>
#define For(a,b,c) for(a=b;a<=c;a++)
using namespace std;
int n,x[10],a,b,c,d,e,f;
bool mark[22][16][16][16][16][16];
inline void out(int c){putchar(c<=9?c+'0':c-10+'a');}
inline bool insert(){
register int id=0;
For(a,0,6)For(b,a+1,6)For(c,b+1,6)For(d,c+1,6)For(e,d+1,6){
if(mark[++id][x[a]][x[b]][x[c]][x[d]][x[e]])return 0;
}
id=0;
For(a,0,6)For(b,a+1,6)For(c,b+1,6)For(d,c+1,6)For(e,d+1,6){
mark[++id][x[a]][x[b]][x[c]][x[d]][x[e]]=1;
}
}
int main(){
scanf("%d",&n);
For(x[0],0,15)For(x[1],0,15)For(x[2],0,15)For(x[3],0,15)
For(x[4],0,15)For(x[5],0,15)For(x[6],0,15)if(insert()){
if(!--n){
int i;For(i,0,6)out(x[i]);
return 0;
}
}
}

[Cqoi2015] 编号 【逆向思维,暴力枚举】的更多相关文章

  1. CodeForces 742B Arpa’s obvious problem and Mehrdad’s terrible solution (暴力枚举)

    题意:求定 n 个数,求有多少对数满足,ai^bi = x. 析:暴力枚举就行,n的复杂度. 代码如下: #pragma comment(linker, "/STACK:1024000000 ...

  2. 2014牡丹江网络赛ZOJPretty Poem(暴力枚举)

    /* 将给定的一个字符串分解成ABABA 或者 ABABCAB的形式! 思路:暴力枚举A, B, C串! */ 1 #include<iostream> #include<cstri ...

  3. HNU 12886 Cracking the Safe(暴力枚举)

    题目链接:http://acm.hnu.cn/online/?action=problem&type=show&id=12886&courseid=274 解题报告:输入4个数 ...

  4. 51nod 1116 K进制下的大数 (暴力枚举)

    题目链接 题意:中文题. 题解:暴力枚举. #include <iostream> #include <cstring> using namespace std; ; ; ch ...

  5. Codeforces Round #349 (Div. 1) B. World Tour 最短路+暴力枚举

    题目链接: http://www.codeforces.com/contest/666/problem/B 题意: 给你n个城市,m条单向边,求通过最短路径访问四个不同的点能获得的最大距离,答案输出一 ...

  6. bzoj 1028 暴力枚举判断

    昨天梦到这道题了,所以一定要A掉(其实梦到了3道,有两道记不清了) 暴力枚举等的是哪张牌,将是哪张牌,然后贪心的判断就行了. 对于一个状态判断是否为胡牌,1-n扫一遍,然后对于每个牌,先mod 3, ...

  7. POJ-3187 Backward Digit Sums (暴力枚举)

    http://poj.org/problem?id=3187 给定一个个数n和sum,让你求原始序列,如果有多个输出字典序最小的. 暴力枚举题,枚举生成的每一个全排列,符合即退出. dfs版: #in ...

  8. hihoCoder #1179 : 永恒游戏 (暴力枚举)

    题意: 给出一个有n个点的无向图,每个点上有石头数个,现在的游戏规则是,设置某个点A的度数为d,如果A点的石子数大于等于d,则可以从A点给每个邻接点发一个石子.如果游戏可以玩10万次以上,输出INF, ...

  9. CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)

    问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...

随机推荐

  1. leetcode-8-字符串转换整数(atoi)

    题目描述: 方法一:正则 class Solution: def myAtoi(self, str: str) -> int: return max(min(int(*re.findall('^ ...

  2. Android App上架流程

    想要把APP上架到应用市场都要先注册开发者账号才可以.这里的方法包括注册帐号和后期上架及一些需要注意的问题.注意:首次提交应用绝对不能随便删除,否则后面再提交会显示应用APP冲突,会要求走应用认领流程 ...

  3. CSS——滑动门技术及应用

    先来体会下现实中的滑动门,或者你可以叫做推拉门: 滑动门出现的背景 制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,最大的问题是里面的字数不一样多,咋 ...

  4. git使用过程中问题

    git提交文件命令顺序 fetch merge add commit pull push 取消已add文件 git reset HEAD 文件名 覆盖本地文件 git checkout 文件名 $ g ...

  5. 0908CSP-S模拟测试赛后总结

    我早就料到昨天会考两场2333 话说老师终于给模拟赛改名了啊. 距离NOIP祭日还有60天hhh. 以上是废话. %%%DeepinC无敌神 -rank1 zkt神.kx神.动动神 -rank2 有钱 ...

  6. spring Cache + Redis 开发数据字典以及自定义标签

    一.数据库表结构 1.  分类表:dict_type 2.  子项表:dict_entry 二.页面维护功能示意图: 1.  分类管理 点击子项管理进入子项管理页面 2.子项管理 三.数据字典添加到缓 ...

  7. Vue+Iview+Node 搭建数据模拟接口

    1.初始化node 项目 2.安装需要部件 3.编写简单代码 routers=>:index.js  login.js  users.js 根目录 index.js var express=re ...

  8. day 67 Django基础三之视图函数

    Django基础三之视图函数   本节目录 一 Django的视图函数view 二 CBV和FBV 三 使用Mixin 四 给视图加装饰器 五 Request对象 六 Response对象 一 Dja ...

  9. Traveling by Stagecoach /// 状压DP oj22914

    题目大意: 输入n,m,p,a,b n是车票数(1<=n<=8),m是城市数(2<=m<=30) p是路径数(可能为0),a是起点,b是终点 接下来一行有n个数 为每张车票的马 ...

  10. js 获取自定义属性值

    html: <p tid="1" onClick="change()">111</p> <p tid="2" ...