【hdu3555】Bomb 数位dp
题目描述
求 1~N 内包含数位串 “49” 的数的个数。
输入
The first line of input consists of an integer T (1 <= T <= 10000), indicating the number of test cases. For each test case, there will be an integer N (1 <= N <= 2^63-1) as the description.
The input terminates by end of file marker.
输出
For each test case, output an integer indicating the final points of the power.
样例输入
3
1
50
500
样例输出
0
1
15
题解
数位dp
设 $f[i][j][0/1]$ 表示 $i$ 位数,最高位为 $j$ ,是否包含数位串 “49” 的数的个数。
首先预处理出 $f$ 数组,根据是否以前有“49”或能构成“49”来更新新的 $f$ 值。
然后对于每个询问跑数位dp:先计算位数不满 $n$ 的位数的数的答案,然后从高位到低位计算,统计该位小于该数当前位的的数,相等的位考虑下一位。
注意统计当前位时需要同时考虑前面是否有“49”,两个数位能否拼成“49”,后面是否有“49”。然而本题数字串的第二位是“9”,枚举时枚举不到9,因此不需要考虑前后两个数位拼成“49”的情况。
把询问转化为 $[1,n)$ 的区间会更容易些。
代码中为了避免一些细节(比如 $10^{19}$ 爆long long之类的),使用了unsigned long long。
#include <cstdio>
typedef unsigned long long ull;
ull f[20][10][2] , b[20];
void init()
{
int i , j , k , l;
f[0][0][0] = b[0] = 1;
for(i = 1 ; i < 20 ; i ++ )
{
b[i] = b[i - 1] * 10;
for(j = 0 ; j < 10 ; j ++ )
for(k = 0 ; k < 10 ; k ++ )
for(l = 0 ; l < 2 ; l ++ )
f[i][j][l || (j == 4 && k == 9)] += f[i - 1][k][l];
}
}
ull calc(ull n)
{
int i , j , di = 1 , flag = 0 , last = 0 , now;
ull ans = 0;
for(i = 1 ; b[i] <= n ; i ++ )
for(j = 1 ; j < 10 ; j ++ )
ans += f[i][j][1];
for( ; i ; i -- )
{
now = n / b[i - 1] % 10;
for(j = di ; j < now ; j ++ )
ans += f[i][j][1] + f[i][j][0] * flag;
if(last == 4 && now == 9) flag = 1;
di = 0 , last = now;
}
return ans;
}
int main()
{
init();
int T;
ull n;
scanf("%d" , &T);
while(T -- ) scanf("%llu" , &n) , printf("%llu\n" , calc(n + 1));
return 0;
}
【hdu3555】Bomb 数位dp的更多相关文章
- hdu---(3555)Bomb(数位dp(入门))
		
Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submi ...
 - HDU3555 Bomb —— 数位DP
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3555 Bomb Time Limit: 2000/1000 MS (Java/Others) M ...
 - hdu3555 Bomb(数位dp)
		
题目传送门 Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total ...
 - hdu3555 Bomb 数位DP入门
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3555 简单的数位DP入门题目 思路和hdu2089基本一样 直接贴代码了,代码里有详细的注释 代码: ...
 - HDU3555 Bomb[数位DP]
		
Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submi ...
 - HDU3555 Bomb 数位DP第一题
		
The counter-terrorists found a time bomb in the dust. But this time the terrorists improve on the ti ...
 - hdu3555 Bomb (数位dp入门题)
		
Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submi ...
 - HDU 3555 Bomb 数位dp
		
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3555 Bomb Time Limit: 2000/1000 MS (Java/Others) Mem ...
 - hud 3555 Bomb 数位dp
		
Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Subm ...
 
随机推荐
- 20145234黄斐《Java程序设计》第三周学习总结
			
教材学习内容总结 类与对象 定义:对象,与过程相对. Java中变量有2种类型,一个是基本类型,另一个则是类类型.基本类型在之前学过,本次学习类类型.使用Java撰写程序几乎都是在使用对象,要产生对象 ...
 - C#使用API屏蔽系统热键和任务管理器
			
最近做的一个winform类型的项目中需要屏蔽系统热键,在网上搜索了一下,基本上都是调用api来进行hook操作,下面的代码就可以完成功能 using System; using System.IO; ...
 - 关于java的wait、notify、notifyAll方法
			
wait.notify.notifyAll 遇到的问题 之前开发打印机项目,因为需要使用多线程技术,当时并不怎么理解,一开始随意在方法体内使用wait.notify.notifyAll 方法导致出现了 ...
 - 北京Uber优步司机奖励政策(2月2日)
			
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
 - 每天看一片代码系列(一):stream.js
			
简介 stream.js是一个小型的js库,用于处理stream相关的操作.这里的stream是指一种数据结构,它像数组一样,可以放置多个类型的数据,但是并不限制长度,甚至可以达到无限长.可以对该数据 ...
 - [hdu 6184 Counting Stars(三元环计数)
			
hdu 6184 Counting Stars(三元环计数) 题意: 给一张n个点m条边的无向图,问有多少个\(A-structure\) 其中\(A-structure\)满足\(V=(A,B,C, ...
 - cakephp2.x 一个ajax例子.md
			
CakePHP中的ajax还是比较简单,但要注意一些细节. app/View/Layouts下新建ajaxtest.ctp <!DOCTYPE html PUBLIC "-//W3C/ ...
 - WebDriver--定位元素的8种方式
			
在UI层面的自动化测试开发中,元素的定位与操作是基础,也是经常遇到的困难所在.webdriver提供了8种定位: 1. id定位:find_element_by_id("id值") ...
 - hdu1176免费馅饼(动态规划,数塔)
			
免费馅饼 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
 - centos下php环境安装redis
			
一.安装redis(仅可在服务器使用,尚不能通过浏览器访问) (1)首先下载redis:wget http://download.redis.io/releases/redis-4.0.9.tar.g ...