题意:

   将含有连续的三个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. 使用 logback + slf4j 进行日志记录

    此处主要介绍maven web工程下如何使用 logback + slf4j  进行日志记录. logback主要包含三个组成部分:Loggers(日志记录器).Appenders(输出目的在).La ...

  2. C# 通过hessian调Java注意事项

    照理说C#可以通过标准的web服务可以轻松地调用Java,但是鉴于hessian的高性能及开发效率,个人认为C#通过hessian调用java是很值得提倡的.之前完成的一个比较大型的企业应用项目就是采 ...

  3. js 表单不为空,数字长度验证

    $(document).ready(function() {    //聚焦第一个输入框    $("#invtype").focus();                     ...

  4. Deep Learning 学习随记(五)深度网络--续

    前面记到了深度网络这一章.当时觉得练习应该挺简单的,用不了多少时间,结果训练时间真够长的...途中debug的时候还手贱的clear了一下,又得从头开始运行.不过最终还是调试成功了,sigh~ 前一篇 ...

  5. cas的url中去掉jsessionid

    Servlet3.0规范中的<tracking-mode>允许你定义JSESSIONID是存储在cookie中还是URL参数中.如果会话ID存储在URL中,那么它可能会被无意的存储 在多个 ...

  6. javascript——操作符(~、&、|、^、<<、>>)

    直接上代码吧! <script type="text/javascript"> //javascript操作符 //1.按位非~ var num1=25;// var ...

  7. jQuery慢慢啃之属性(三)

    1.attr(name|properties|key,value|fn)设置或返回被选元素的属性值. $("img").attr("src");//获取属性 $ ...

  8. wordpress 更改 "Home"为"首页"

    要怎麼更改wordpress的 menu上 那一直顯示著"首頁"的頁籤呢這問題我實在是找好久終於給我找到 在 wp-includes 的 post-template.php 這檔案 ...

  9. A*算法深入

    A*算法思想容易理解,但要想设计出好的A*算法,则必需要全面深入了解它.在本文章中接下来的内容中,将全面深入探讨该话题.如果对该算法还没有理解的话,则请先查阅上篇文章<A*算法入门>,然后 ...

  10. Java初试

    另外在Java语言的代码内部书写文件路径时,需要注意大小写,大小写需要保持一致,路径中的文件夹名称区分大小写.由于’\’是Java语言中的特殊字符,所以在代码内部书写文件路径时,例如代表“c:\tes ...