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模型将是数据通信的最终标准,然而 ...
随机推荐
- 10步写了个Django网站,正经网站···
Django做网站只要10步,真的只有10步,不信?咱们来数数-- 今天主要讲解用Pycharm编辑器搭建网站,网站功能是 实现在局域网中快速传递大文件! 比如:同事要给你个1G的文件,你丢一 ...
- 【MyBatis】自定义 MyBatis
自定义 MyBatis 文章源码 执行查询信息的分析 我们知道,MyBatis 在使用代理 DAO 的方式实现增删改查时只做两件事: 创建代理对象 在代理对象中调用 selectList() 配置信息 ...
- Linux 服务器安装node环境
Linux 装 node 环境 我的是 CentOS 查看服务器是多少位系统 getconf LONG_BIT 下载地址, 下载对应的版本: http://nodejs.cn/download/ 我这 ...
- 【高级排序算法】2、归并排序法的实现-Merge Sort
简单记录 - bobo老师的玩转算法系列–玩转算法 -高级排序算法 Merge Sort 归并排序 Java实现归并排序 SortTestHelper 排序测试辅助类 package algo; im ...
- 利用Python-docx 读写 Word 文档中的正文、表格、段落、字体等
前言: 前两篇博客介绍了 Python 的 docx 模块对 Word 文档的写操作,这篇博客将介绍如何用 docx 模块读取已有 Word 文档中的信息. 本篇博客主要内容有: 1.获取文档的章节信 ...
- kill 指令的执行原理
kill 指令有两种写法 " kill query + 线程 id "." kill connection(可缺省) + 线程 id ".分别表示关闭指定线程正 ...
- LeetCode572. 另一个树的子树
题目 本题目一开始想要通过二叉树遍历KMP匹配,但看来实现比较复杂 不如直接暴力匹配,本题和LeetCode100.相同的树有共通之处 1 class Solution { 2 public: 3 b ...
- 使用 TensorBoard 可视化模型、数据和训练
使用 TensorBoard 可视化模型.数据和训练 在 60 Minutes Blitz 中,我们展示了如何加载数据,并把数据送到我们继承 nn.Module 类的模型,在训练数据上训练模型,并在测 ...
- unity3D进阶
前言 在之前的例子中,我们都没有用到unity的精髓,例如地形系统.物理系统.粒子系统等,本文记录unity3D的进阶简单应用 前期准备 https://unity.cn/releases/full/ ...
- ETCD数据迁移
ETCD数据迁移 本文阅读对象为想要将Rainbond平台rbd-etcd切换至外部etcd的相关人员. 在k8s master节点创建secret 本文中将要切换的ETCD为根据Rainbond官方 ...