题目地址:HDU 4901

这题没想到最后竟然可以做出来。。

。。

这题用了两次DP,先从前往后求一次异或的。再从后往前求一次与运算的。

各自是

1:求异或的时候,定义二维数组huo[1000][1024],前者指第几位,后者是哈希的思想。若huo[x][y]=2则表示最右边的数为第x位时,异或值为y的出现了两次,须要再定义一个hash数组。来保存前面出现的全部情况。再找有多少位的时候,用hash数组中出现的全部的值与当前的第x位的数字进行异或。

2:求与的时候,定义二维数组yu[1000][1024]。同异或的差点儿相同,只是这里的位数是指从这位往后的全部的情况。而异或的是指必须包括该位。

因为与运算本身就是求的全部的情况,不用再定义hash数组。

3:然后从前往后開始匹配。仅仅要用huo[x]与yu[x+1]进行匹配就好了。假设两者出现了同样的异或值,那就将次数相乘。

终于的答案即是正确答案。

注意。在运算的过程中数组里的数会出现爆long long的情况。。所以须要每一步都要求余。。

(由于这个而错了好几次。。)

代码例如以下。

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
__int64 huo[1003][1125], yu[1003][1125], a[1013], _hash[1003][1030];
const int mod=1e9+7;
int main()
{
__int64 t, n, i, j, k;
__int64 s;
scanf("%I64d",&t);
while(t--)
{
s=0;
memset(huo,0,sizeof(huo));
memset(yu,0,sizeof(yu));
scanf("%I64d",&n);
for(i=1; i<=n; i++)
{
scanf("%I64d",&a[i]);
}
memset(_hash,0,sizeof(_hash));
for(i=1; i<=n; i++)
{
for(j=0; j<=1024; j++)
{
if(_hash[i-1][j])
{
_hash[i][a[i]^j]+=_hash[i-1][j];
_hash[i][a[i]^j]%=mod;
huo[i][a[i]^j]+=_hash[i-1][j];
huo[i][a[i]^j]%=mod;
_hash[i][j]+=_hash[i-1][j];
_hash[i][j]%=mod;
}
}
_hash[i][a[i]]++;
huo[i][a[i]]++;
}
for(i=n; i>=1; i--)
{
for(j=0; j<=1024; j++)
{
if(yu[i+1][j])
{
yu[i][a[i]&j]+=yu[i+1][j];
yu[i][a[i]&j]%=mod;
yu[i][j]+=yu[i+1][j];
yu[i][j]%=mod;
}
}
yu[i][a[i]]++;
}
for(i=1; i<=n; i++)
{
for(j=0; j<=1024; j++)
{
if(huo[i][j]&&yu[i+1][j])
{
s=(s+huo[i][j]*yu[i+1][j])%mod;
}
}
}
printf("%I64d\n",s);
}
return 0;
}

HDU 4901(杭电多校训练#3 1005题)The Romantic Hero(DP)的更多相关文章

  1. HDU 4920(杭电多校训练#5 1010 题) Matrix multiplication(不知道该挂个什么帽子。。。)

    题目地址:pid=4920">HDU 4920 对这个题简直无语到极点. . .竟然O(n^3)的复杂度能过....方法有三.. 1:进行输入优化和输出优化. . (前提是你的输入优化 ...

  2. HDU 4941 Magical Forest(map映射+二分查找)杭电多校训练赛第七场1007

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4941 解题报告:给你一个n*m的矩阵,矩阵的一些方格中有水果,每个水果有一个能量值,现在有三种操作,第 ...

  3. HDU 4902 Nice boat 2014杭电多校训练赛第四场F题(线段树区间更新)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4902 解题报告:输入一个序列,然后有q次操作,操作有两种,第一种是把区间 (l,r) 变成x,第二种是 ...

  4. HDU 4864 Task (贪心+STL多集(二分)+邻接表存储)(杭电多校训练赛第一场1004)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4864 解题报告:有n台机器用来完成m个任务,每个任务有一个难度值和一个需要完成的时间,每台机器有一个可 ...

  5. 【单调栈】hdu 6319 杭电多校Problem A. Ascending Rating

    http://acm.hdu.edu.cn/showproblem.php?pid=6319 从后往前更新,维护一个递减单调栈(队列) 最近很多题都是单调栈... #define _CRT_SECUR ...

  6. HDU 4970(杭电多校#9 1011题)Killing Monsters(瞎搞)

    题目地址:HDU 4970 先进行预处理.在每一个炮塔的火力范围边界标记一个点. 然后对每一个点的伤害值扫一遍就能算出来. 然后在算出每一个点到终点的总伤害值,并保存下来,也是扫一遍就可以. 最后在询 ...

  7. HDU 4968(杭电多校#9 1009题)Improving the GPA (瞎搞)

    题目地址:HDU 4968 这题的做法是全部学科的学分情况枚举,然后推断在这样的情况下是否会符合平均分. 直接暴力枚举就可以. 代码例如以下: #include <cstring> #in ...

  8. [2019杭电多校第一场][hdu6583]Typewriter(后缀自动机&&dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6583 大致题意是说可以花费p在字符串后添加一个任意字符,或者花费q在字符串后添加一个当前字符串的子串. ...

  9. 2018杭电多校第三场1003(状态压缩DP)

    #include<bits/stdc++.h>using namespace std;const int mod =1e9+7;int dp[1<<10];int cnt[1& ...

随机推荐

  1. 《深入.NET平台和C#编程》内部测试题-笔试试卷

    1.以下关于序列化和反序列化的描述错误的是( C). a.序列化是将对象的状态存储到特定存储介质中的过程 b.二进制格式化器的Serialize()和Deserialize()方法可以用来实现序列化和 ...

  2. javascript 学习笔记之面向对象编程(二):继承&多态

    ~~接上篇~~上一篇实现了类的实现以及类成员变量和方法的定义,下面我们来了解下面向对象中两个最重要的特性:继承和多态. 继承 js中同样可以实现类的继承这一面向对象特性,继承父类中的所有成员(变量和属 ...

  3. css3多行省略号

    -webkit-line-clamp 概述: -webkit-line-clamp 是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中. ...

  4. AppDomain与进程、线程、Assembly之间关系

    AppDomain是CLR的运行单元,它可以加载Assembly.创建对象以及执行程序 AppDomain是CLR实现代码隔离的基本机制.   每一个AppDomain可以单独运行.停止:每个AppD ...

  5. C语言变量声明加冒号的用法

    有些信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位.例如在存放一个开关量时,只有0和1 两种状态, 用一位二进位即可.为了节省存储空间,并使处理简便,C语言又提供了一种数据结构 ...

  6. General Purpose Hash Function Algorithms

    General Purpose Hash Function Algorithms post@: http://www.partow.net/programming/hashfunctions/inde ...

  7. 工欲善其事必先利其器-Notepad++使用小记(Python)

    大学开始就一直使用Notepad++ 作为代码编辑器,喜欢它的简洁明了,喜欢它的个性,也喜欢它各种各样骚气的插件. 今天闲来无事,写篇文章记录一下平时使用的种种,包括但不限于个性化使用一些宏,快捷键, ...

  8. C语言学习笔记(一):数组传递时退化为指针

    这几天闲来无事,写了一个数组元素排序函数如下: #include <stdio.h> #include <stdlib.h> void ArraySort(int array[ ...

  9. 关于mysql授权账号权限时的空密码问题

    -root ~]$ mysql -uroot -p Enter password:ERROR 1045 (28000): Access denied for user ‘root’@'localhos ...

  10. Solr总结

    http://www.cnblogs.com/guozk/p/3498831.html Solr调研总结 开发类型 全文检索相关开发 Solr版本 4.2 文件内容 本文介绍solr的功能使用及相关注 ...