HDU 5632 Rikka with Array [想法题]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5632
------------------------------------------------------------------------------------------
这场比赛的官方题解说这题比较明显, 然而我比赛完后对着题解看了好久也没有想明白
于是先做了几道数位$DP$找找感觉 可惜感觉并没有找到
这题和传统数位$DP$不一样 这题是求范围内满足要求的数对的个数
既然是数对 我们记录时便不再记录数的状态 而是记录两数之间的关系的状态
不过官方题解只记录 考虑到了哪位 两数$1$的个数差的绝对值
大数$1$的个数是否不小于小数$1$的个数 这三个部分
可惜自己做的时候总感觉只记录这些状态还不够
然后$Cwind$前辈提供了一个思路 额外记录两个部分
大小两数当前位之前是否相等 大数当前位之前是否与限制条件相等
------------------------------------------------------------------------------------------
用以上的思路就可以比较轻松的用记忆化搜索做了
不过由于状态多两维 而且一开始的写法每次询问都需要重新计算 因而时间比较挫 要$1.4s$
观察后可发现如果较大数的当前位之前于限制条件不等 那么后面的数的选取都是任意的
所以这种情况下并不用每次重新计算 加了这个常数优化后要 $0.6s$
再加上一个对于当前状态贡献一定是$0$的剪枝后还要$0.48s$
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
const int N = , mod = ;
int f[N][N][][][], cnt[N][N][][][];//cnt记录的是时间戳
bool bin[N];
int num[];
char s[];
int t, len, n;
void init()
{
n = ;
while(len)
{
for(int i = len; i; --i)
{
num[i - ] += (num[i] & ) * ;
num[i] >>= ;
}
bin[++n] = (num[] != );
num[] = ;
if(!num[len])
--len;
}
}
int dfs(int x, int dif, bool over, bool same, bool top)
{
if(cnt[x][dif][over][same][top] == t + ||
(cnt[x][dif][over][same][top] && !top))
return f[x][dif][over][same][top];
cnt[x][dif][over][same][top] = t + ;
if(!x)
return f[x][dif][over][same][top] = !over;
if(over && dif >= x)
return f[x][dif][over][same][top] = ;
int re = ;
if(!top || bin[x])
{
re += dfs(x - , dif, over, same, top);
re += dfs(x - , dif + (over ? : -), over || dif == , , top);
re = (re >= mod ? re - mod : re);
}
if(!same)
{
re += dfs(x - , abs(dif + (over ? - : )), over && dif, , top && !bin[x]);
re = (re >= mod ? re - mod : re);
}
re += dfs(x - , dif, over, same, top && !bin[x]);
re = (re >= mod ? re - mod : re);
return f[x][dif][over][same][top] = re;
}
int main()
{
scanf("%d", &t);
while(t--)
{
scanf("%s", s + );
len = strlen(s + );
for(int i = ; i <= len; ++i)
num[i] = s[len - i + ] - '';
init();
printf("%d\n", dfs(n, , , , ));
}
return ;
}
想到/理解了 更好的方法再来改改吧
HDU 5632 Rikka with Array [想法题]的更多相关文章
- HDU - 5806 NanoApe Loves Sequence Ⅱ 想法题
http://acm.hdu.edu.cn/showproblem.php?pid=5806 题意:给你一个n元素序列,求第k大的数大于等于m的子序列的个数. 题解:题目要求很奇怪,很多头绪但写不出, ...
- HDU 4972 Bisharp and Charizard 想法题
Bisharp and Charizard Time Limit: 1 Sec Memory Limit: 256 MB Description Dragon is watching NBA. He ...
- HDU - 5969 最大的位或 想法题
http://acm.hdu.edu.cn/showproblem.php?pid=5969 (合肥)区域赛签到题...orz 题意:给你l,r,求x|y的max,x,y满足l<=x<=y ...
- hdu 5532 Almost Sorted Array (水题)
Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- 【HDOJ】5632 Rikka with Array
1. 题目描述$A[i]$表示二级制表示的$i$的数字之和.求$1 \le i < j \le n$并且$A[i]>A[j]$的$(i,j)$的总对数. 2. 基本思路$n \le 10^ ...
- hdu 6095 Rikka with Competition---思维题贪心
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6095 题目大意: 任意两个人相比,相差大于K,分低的淘汰,否则两人都有可能赢,剩下的继续比,问有最多 ...
- HDU 4638 树状数组 想法题
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4638 解题思路: 题意为询问一段区间里的数能组成多少段连续的数.先考虑从左往右一个数一个数添加,考虑当 ...
- HDU 5908 Abelian Period(暴力+想法题)
传送门 Description Let S be a number string, and occ(S,x) means the times that number x occurs in S. i. ...
- hdu 5063 不错的小想法题(逆向处理操作)
题意: 刚开始的时候给你一个序列,长度为n,分别为a[1]=1,a[2]=2,a[3]=3,a[4]=4...a[n]=n,然后有4种操作如下: Type1: O 1 call fun1( ...
随机推荐
- NornJ-javascript模版引擎
NornJ-javascript模版引擎 NornJ是一个渲染效率高,语法可读性好,可扩展性超强,适用场景丰富的javascript模板引擎. 学习网址:https://www.npmjs.com/p ...
- c# asp.net uploadify 上传大文件 出现的 HTTP 404 问题
用uploadify在IIS6下上传大文件没有问题,但是迁移到IIS7下面,上传大文件时,出现HTTP 404错误. 查了半天,原来是IIS7下的默认设置限制了上传大小.这个时候Web.Config中 ...
- display:table
display:table的CSS声明能够让一个HTML元素和它的子节点像table元素一样.使用基于表格的CSS布局,使我们能够轻松定义一个单元格的边界.背景等样式,而不会产生因为使用了table那 ...
- <<Java RESTful Web Service实战>> 读书笔记
<<Java RESTful Web Service实战>> 读书笔记 第一章 JAX-RS2.0入门 REST (Representational State ransf ...
- 通过总线机制实现自动刷新客户端配置(Consul,Spring Cloud Config,Spring Cloud Bus)
通过总线机制实现自动刷新客户端配置 方案示意图 利用Git服务的webhook通知功能,在每次更新配置之后,Git服务器会用POST方式调用配置中心的/actuator/bus-refresh接口,配 ...
- [2019杭电多校第二场][hdu6601]Keen On Everything But Triangle
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6601 题意是说用给定区间内的数字组成周长最大的三角形. 大致做法就是求区间第1大,第2大和第3大然后判 ...
- [2019杭电多校第二场][hdu6598]Harmonious Army(最小割)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6598 题意是说一个军队有n人,你可以给他们每个人安排战士或者法师的职业,有m对人有组合技,组合技的信息 ...
- 国内下载Flutter
出现镜像错误等现象属于源码包不全面,国内下载镜像添加环境变量. ①:Linux执行如下操作 export PUB_HOSTED_URL=https://pub.flutter-io.cn export ...
- xml转dict
xml转dict 最开始的时候一直是按格式比较严谨的XML格式进行的转换,所以一般只需要考虑两种情况就可以了,即各个节点或者子节点全相同或者全不同,全相同按list处理,全不同按dict处理,这么一想 ...
- Codeforces Round #340 (Div. 2) E. XOR and Favorite Number (莫队)
题目链接:http://codeforces.com/contest/617/problem/E 题目大意:有n个数和m次查询,每次查询区间[l, r]问满足ai ^ ai+1 ^ ... ^ aj ...