题意:

   将含有连续的三个6的数称为不吉利数,比如666,1666,6662,但是6266吉利。则666为第一个不吉利数,输入整数n,求第n个不吉利数。(n <= 5*10^7)

解法:

   如果是给出n,求n以内的不吉利数有多少个,就是一个普通的数位DP。所以,就二分答案,对于每一个mid,求一下小于等于mid的数中不吉利数的个数。

tag:二分法,数位DP

 /*
* Author: Plumrain
* Created Time: 2013-12-14 20:55
* File Name: DP-POJ-3208.cpp
*/
#include <iostream>
#include <cstdio>
#include <cstring> using namespace std; #define CLR(x) memset(x, 0, sizeof(x))
typedef long long int64;
int64 d1[][][], d2[][][]; int64 get_num(int64 x)
{
int len = , dit[];
bool xxx = ;
while (x){
dit[len++] = x % ;
x /= ;
if (len > && dit[len-] == && dit[len-] == && dit[len-] == )
xxx = ;
}
dit[len] = ; dit[len+] = ; int64 ret = ;
if (xxx) ret = ;
bool flag = ;
for (int i = len-; i >= ; -- i){
for (int j = ; j < ; ++ j)
for (int k = ; k < ; ++ k)
ret += dit[i] * d2[i][j][k]; if (flag){
for (int j = ; j < ; ++ j)
for (int k = ; k < ; ++ k)
ret += dit[i] * d1[i][j][k];
}
else {
if (dit[i+] == && dit[i+] == && dit[i] > ){
for (int j = ; j < ; ++ j)
for (int k = ; k < ; ++ k)
ret += d1[i][j][k];
}
else if (dit[i+] == && dit[i] > ){
for (int j = ; j < ; ++ j)
ret += d1[i][][j];
}
else if (dit[i] > ) ret += d1[i][][];
} if (dit[i] == && dit[i+] == && dit[i+] == )
flag = ;
}
return ret;
} int64 gao(int64 n)
{
int64 l = , r = ;
while (l <= r){
int64 mid = (l + r) >> ;
if (get_num(mid) < n) l = mid + ;
else r = mid - ;
}
return l;
} int main()
{
CLR (d1); CLR (d2);
d1[][][] = ;
for (int i = ; i < ; ++ i){
d1[][i][] = ;
for (int j = ; j < ; ++ j)
d1[][i][j] = ;
} for (int i = ; i < ; ++ i){
d2[i][][] += d1[i-][][];
d1[i][][] -= d1[i-][][];
for (int j = ; j < ; ++ j)
for (int k = ; k < ; ++ k)
for (int l = ; l < ; ++ l){
d2[i][j][k] += d2[i-][k][l];
d1[i][j][k] += d1[i-][k][l];
}
} int T;
scanf ("%d", &T);
while (T--){
int64 n;
cin >> n;
cout << gao(n) << endl;
}
return ;
}

POJ 3208 Apocalypse Someday的更多相关文章

  1. POJ 3689 Apocalypse Someday [数位DP]

    Apocalypse Someday Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 1807   Accepted: 87 ...

  2. poj3208 Apocalypse Someday 数位dp+二分 求第K(K <= 5*107)个有连续3个6的数。

    /** 题目:poj3208 Apocalypse Someday 链接:http://poj.org/problem?id=3208 题意:求第K(K <= 5*107)个有连续3个6的数. ...

  3. POJ3208 Apocalypse Someday

    题意 Language:Default Apocalypse Someday Time Limit: 1000MS Memory Limit: 131072K Total Submissions: 2 ...

  4. Apocalypse Someday

    Apocalypse Someday 定义一个数是合法的,当且仅当中间出现至少一个连续的大于三个的6,求第x个合法的数,\(x\leq 50,000,000\) 解 首先,注意到求第几个,即想到试填法 ...

  5. POJ3208:Apocalypse Someday

    传送门 很神奇的一道题,正解是AC自动机+数位DP,个人感觉POPOQQQ大爷的方法更方便理解. 按照一般套路,先搞个DP预处理,设$f[i][0/1/2/3]$分别表示对于$i$位数,其中有多少个前 ...

  6. POJ3208 Apocalypse Someday(二分 数位DP)

    数位DP加二分 //数位dp,dfs记忆化搜索 #include<iostream> #include<cstdio> #include<cstring> usin ...

  7. 【POJ3208】Apocalypse Someday

    Description 666号被认为是神秘的"野兽之数",在所有以启示录为主题的大片中都是一个被广泛使用的数字.但是,这个数字666不能总是在脚本中使用,所以应该使用1666这样 ...

  8. poj3208 Apocalypse Someday[数位DP]

    数位中出现至少3个连续的'6'的数字(称魔鬼数),询问满足要求的排名k的数. 经典题型.采用试填法. 递推做法:预处理出$i$位数字中满足要求的数(下记为'魔鬼数').对每一位都从0到9试一遍,然而卡 ...

  9. POJ-3208 Apocalypse Someday (数位DP)

    只要某数字的十进制表示中有三个6相邻,则该数字为魔鬼数,求第X小的魔鬼数\(X\le 5e7\) 这一类题目可以先用DP进行预处理,再基于拼凑思想,用"试填法"求出最终的答案 \( ...

随机推荐

  1. .Net实现IO操作

    IO操作需要的web.config里的节点配置 <configuration>  <appSettings>    <!--上传文件类型要求-->    <a ...

  2. Oracle IN 传递字符串参数查询失效

    在写存储过程中有如下代码: FOR a IN ( SELECT a.svo_no,a.AUDIT_NO,a.order_id FROM TT_PI_MODEL_REL a ) LOOP SELECT ...

  3. call 方法在使用一个指定的this值和若干个指定的参数值的前提下调用某个函数或方法.

    call 方法在使用一个指定的this值和若干个指定的参数值的前提下调用某个函数或方法. 注意:该函数的语法与 apply() 方法的语法几乎完全相同,唯一的区别在于,apply()方法接受的是一个参 ...

  4. Bootstrap_Javascript_滚动监视器

    滚动监控器是Bootstrap提供的非常实用的JavaScript插件,被广泛应用到Web开发中.其表现形式是: 1.当用户鼠标滚动时,滚动条的位置会自动更新导航条中相应的导航项. 2.用户拖动滚动条 ...

  5. Chrome 中的彩蛋——T-Rex

    今天,从网页上看到chrome的T-Rex的彩蛋,眨眼间完了10分钟.分享出来,只是好玩. 当 Chrome 无法连接到互联网时,或者上着网突然掉线,刷新页面时报错,我们都会看到T-Rex的身影,没错 ...

  6. actionscript sendToURL请求url,传递http_referer分浏览器统计

    IE全版本都不传递referer,但会在header中传递X_FLASH_VERSION,例如:"HTTP_X_FLASH_VERSION":"13,0,0,182&qu ...

  7. 内存映射+远线程 调用游戏CALL

    源码中 用到的结构和未公开函数 请到 http://www.cnblogs.com/IMyLife/p/4826286.html 获取 HANDLE ProcessHandle=NULL; DWORD ...

  8. iOS · 安装RVM cocoaPods 及问题解决

    一.安装RVM 1.RVM:ruby版本管理器,命令行工具 管理Ruby 开始安装吧~ 对!!就是这样换成taobao ⬇️ $ gem sources -l $ gem sources --remo ...

  9. ios的Ping++支付接入步骤-b

    1. Client 发送支付要素给 Server 2. Server 发送支付请求并将返回的支付凭据传给 Client 3. Client 调起支付控件完成支付 4. 渠道同步返回支付结果给 Clie ...

  10. gridview checkbox从服务器端和客户端两个方面实现全选和反选

    GridView中的checkbox的全选和反选在很多的地方都是要求实现的,所以下面就从服务器端和客户端两个方面实现了checkbox的选择,感兴趣的朋友可以了解下,希望本文对你有所帮助 GridVi ...