Luogu U13059 某种密码
应该没什么用的题目链接
题目背景
关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY。若KEY=∑▒〖Ai*Bi〗,则密文就是原文的一组合法密码。
题目描述
现在有原文和钥匙码,请编一个程序来帮助他统计到底有多少个符合条件的密文。
输入输出格式
输入格式:
第一行两个数N,KEY,意义同题目描述;
第二行N个数表示原文A,意义同题目描述。
输出格式:
一个数ANS,表示对于原文A和KEY,有多少组可行的密文B。
输入输出样例
3 2
1 1 2
2
说明
【样例说明】
密文110,1*1+1*1+0*2=2
密文001,0*1+0*1+1*2=2
一共两组可行的密文。
【数据范围】
60%数据满足N<=25
100%数据满足N<=40,-maxlongint<=∑▒Ai<=maxlongint
题解:
这道题可以理解为一个01背包问题的变种,n为物品个数,原文为物品的重量,钥匙码为背包容量,求恰好装满背包的方案数。
如果是一道普通01背包求恰好装满背包的方案数的题,可以用DP求解。具体思路是设f[i][j]为用前i个物品恰好装满容量为j的背包的方案数,转移方程为f[i][j]=f[i-1][j]+f[i-1][j-w[i]]。显然可以滚动数组或一维数组优化,在此不再赘述。
然而,观察数据范围会发现,此处物品的重量极大,达到了int的范围,因此DP的时空复杂度均无法承受,然而n的范围较小,可以考虑搜索。
60分做法:
直接暴搜,O(2n)枚举放入背包的物品集合,将重量相加并与key比较。然而,对于剩余的40%数据,复杂度太大,仍然无法解决。
100分做法:
注意到这是一类经典问题,即从一个集合中选取某个子集,使其中所有元素值之和等于某个给定值。可以使用以空间换时间的折半枚举。类似思想也在BSGS中得到应用。
将物品集合均分成两个交集为空,补集为全集的集合A、B,对集合A暴力枚举其所有子集中元素和并存入哈希表(可重集),再对集合B暴力枚举每个子集的元素和s,同时查找哈希表中值为(key-s)的元素个数并计数。时间复杂度为O(2*2n/2)=O(2n/2),可以接受。
注意此处用到的哈希表如果使用STL代替的话,不能使用set,要用multiset或map,然而multiset速度极慢不推荐使用,map速度也稍慢,有被卡1~2个点的风险。不过我自己写的哈希表写挂了只能用map
代码:
1 #include<bits/stdc++.h>
2 #define h(x) (x%MOD)
3 #define LL long long
4 using namespace std;
5 const LL maxn=100,maxm=4e6+10,maxk=1e5+10,MOD=1e5+3;
6 map<int,int>isvis;
7 LL a[maxn];
8 LL n,key,mid,tot=0;LL ans=0;
9 int main()
10 {
11 LL i,j,k,l,r,tmp;
12 cin>>n>>key;
13 //l=n/2;r=n-l;
14 mid=(1+n)>>1;l=mid;r=n-l;
15 for(i=1;i<=n;i++){scanf("%d",&a[i]);}
16 for(k=0;k<(1<<l);k++)
17 {
18 tmp=0;
19 for(i=0;i<l;i++){if(k&(1<<i)){tmp+=a[i+1];}}
20 isvis[tmp]++;
21 }
22 for(k=0;k<(1<<r);k++)
23 {
24 tmp=0;
25 for(i=0;i<r;i++){if(k&(1<<i)){tmp+=a[l+i+1];}}
26 ans+=isvis[key-tmp];
27 }
28 cout<<ans;
29 return 0;
30 }
PS:
此外,还有一类01背包的变种。这类问题中物品个数与普通01背包类似,物品重量与背包容量极大,但物品单个价值较小,求装入背包的物品价值的最大值。
此类问题可以用DP求解,只是需要对状态进行些许修改。设f[i][j]为前i个物品价值总量为j时所需的背包容量的最小值,状态转移方程为f[i][j]=min(f[i-1][j],f[i-1][j-c[i]]+w[i])。最后扫描f[n][i],找到最接近给定背包容量的i输出即可。
Luogu U13059 某种密码的更多相关文章
- 黄学长模拟day1 某种密码
关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY.若KEY=∑▒[Ai*Bi],则密文就是原文的一组合法密码. 现在有原 ...
- 某种密码(password.*)
关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY.若KEY=∑▒[Ai*Bi],则密文就是原文的一组合法密码.现在有原文 ...
- [Luogu] 外星密码
https://www.luogu.org/problemnew/show/P1928 沙比提 读清题目 #include <bits/stdc++.h> using namespace ...
- luogu P3279 [SCOI2013]密码
LINK:密码 给出来manacher的数组 让还原出字典序最小的字符串.字符集为小写字母. 当没有任何限制时 放字典序最小的'a'.如果此时还在最长的回文串中的话那么 直接得到当前字符即可. 注意这 ...
- 2018.11.01 NOIP训练 某种密码(折半搜索)
传送门 直接折半搜索,把所有和装到unorderedmapunordered_mapunorderedmap里面最后统计答案就行了. 然后考试的时候读优并没有处理有负数的情况于是爆零了 代码
- 如何利用神经网络和Python生成指定模式的密码
今天给大家介绍的是Github上一个名叫PyMLProjects的项目,这个项目的目的是为了训练AI来学习人类构造密码的模式,然后我们就可以用AI来生成大量同一模式或种类的密码了.这种方法也许可以用来 ...
- 9.30 noip模拟试题
时限均为1s,内存 256MB 1.某种密码(password.*) 关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY. ...
- SSL/TLS通信
本文同时发表在https://github.com/zhangyachen/zhangyachen.github.io/issues/31 复习基本概念 对称密码:加密和解密使用同一密匙. 公钥密码: ...
- OSI模型和TCP/IP协议族(一)
1990年以前,再数据通信和组网文献中占主导地位的分层模型是开放系统互连(Open System Interconnnection,OSI)模型.当时所有人都认为OSI模型将是数据通信的最终标准,然而 ...
随机推荐
- 基于腾讯云存储COS的ClickHouse数据冷热分层方案
一.ClickHouse简介 ClickHouse是一个用于联机分析(OLAP)的列式数据库管理系统(DBMS),支持PB级数据量的交互式分析,ClickHouse最初是为YandexMetrica ...
- Oracle误删数据的恢复
Oracle误删数据的恢复,分为两种方法:SCN和时间戳两种方法恢复. 一.通过SCN恢复删除且已提交的数据 1.获得当前数据库的SCN号 select current_scn from v$data ...
- linux + svn提交日志不能显示 日期一直都是1970-01-01
网上很多都是说将svn安装目录下的svnserve.conf文件中的anon-access 设置为read,但是 经查阅并测试, 设置为: anon-access = none 是正确的,设置成 r ...
- golang遍历时修改被遍历对象
目录 前言 遍历切片 遍历map 总结 前言 很多时候需要将遍历对象中去掉某些元素,或者往遍历对象中添加元素,这时候就需要小心操作了. 对于go语言中的一些注意事项我做了总结和示例,留下点笔记. 遍历 ...
- GC算法介绍及工作原理和优缺点
一.GC定义与作用 GC就是垃圾回收机制的简写 GC可以找到内存中的垃圾,并释放和回收空间,GC里的垃圾是什么 如下图所示: GC算法是什么:GC是一种机制,垃圾回收器完成具体的工作 工作的内容就是查 ...
- 【Oracle】等待事件之 V$SESSION_WAIT
(1)-V$SESSION_WAIT 这是一个寻找性能瓶颈的关键视图.它提供了任何情况下session在数据库中当前正在等待什么(如果session当前什么也没在做,则显示它最后的等待事件).当系统存 ...
- 【九阳神功】Nessus 8_VM不限IP及AWVS破解版合体部署
Nessus 8下载地址: https://moehu-my.sharepoint.com/personal/ximcx_moebi_org/_layouts/15/download.aspx?Sou ...
- [从源码学设计]蚂蚁金服SOFARegistry之配置信息
[从源码学设计]蚂蚁金服SOFARegistry之配置信息 目录 [从源码学设计]蚂蚁金服SOFARegistry之配置信息 0x00 摘要 0x01 业务范畴 1.1 配置作用 1.2 学习方向 0 ...
- ObjectMapper将josn字符串转化为List
一.利用ObjectMapper将json字符串转为List Student.java package objectmapper; import java.io.Serializable; publi ...
- [Ceoi2004]Journey
题目描述 给出N个点,及你的出发点K. 接下来N-1行描述有关边的开始点,结束点,边长.保证图中不会有环 接下来给出数字J,代表你要走多少个点. 接下来J个数字,代表你要走过的点的编号.当然你可以自己 ...