应该没什么用的题目链接

题目背景

关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY。若KEY=∑▒〖Ai*Bi〗,则密文就是原文的一组合法密码。

题目描述

现在有原文和钥匙码,请编一个程序来帮助他统计到底有多少个符合条件的密文。

输入输出格式

输入格式:

第一行两个数N,KEY,意义同题目描述;

第二行N个数表示原文A,意义同题目描述。

输出格式:

一个数ANS,表示对于原文A和KEY,有多少组可行的密文B。

输入输出样例

输入样例#1:

3 2
1 1 2
输出样例#1:

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 某种密码的更多相关文章

  1. 黄学长模拟day1 某种密码

    关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY.若KEY=∑▒[Ai*Bi],则密文就是原文的一组合法密码. 现在有原 ...

  2. 某种密码(password.*)

    关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY.若KEY=∑▒[Ai*Bi],则密文就是原文的一组合法密码.现在有原文 ...

  3. [Luogu] 外星密码

    https://www.luogu.org/problemnew/show/P1928 沙比提 读清题目 #include <bits/stdc++.h> using namespace ...

  4. luogu P3279 [SCOI2013]密码

    LINK:密码 给出来manacher的数组 让还原出字典序最小的字符串.字符集为小写字母. 当没有任何限制时 放字典序最小的'a'.如果此时还在最长的回文串中的话那么 直接得到当前字符即可. 注意这 ...

  5. 2018.11.01 NOIP训练 某种密码(折半搜索)

    传送门 直接折半搜索,把所有和装到unorderedmapunordered_mapunorderedm​ap里面最后统计答案就行了. 然后考试的时候读优并没有处理有负数的情况于是爆零了 代码

  6. 如何利用神经网络和Python生成指定模式的密码

    今天给大家介绍的是Github上一个名叫PyMLProjects的项目,这个项目的目的是为了训练AI来学习人类构造密码的模式,然后我们就可以用AI来生成大量同一模式或种类的密码了.这种方法也许可以用来 ...

  7. 9.30 noip模拟试题

    时限均为1s,内存 256MB 1.某种密码(password.*) 关于某种密码有如下描述:某种密码的原文A是由N个数字组成,而密文B是一个长度为N的01数串,原文和密文的关联在于一个钥匙码KEY. ...

  8. SSL/TLS通信

    本文同时发表在https://github.com/zhangyachen/zhangyachen.github.io/issues/31 复习基本概念 对称密码:加密和解密使用同一密匙. 公钥密码: ...

  9. OSI模型和TCP/IP协议族(一)

    1990年以前,再数据通信和组网文献中占主导地位的分层模型是开放系统互连(Open System Interconnnection,OSI)模型.当时所有人都认为OSI模型将是数据通信的最终标准,然而 ...

随机推荐

  1. Rancher首席架构师解读Fleet:它何以管理百万集群?

    作者简介 Darren Shepherd,Rancher Labs联合创始人及首席架构师.在加入Rancher之前,Darren是Citrix的高级首席工程师,他在那里从事CloudStack.Ope ...

  2. 【Flutter】容器类组件之Container容器

    前言 Container是一个组合类容器,它本身不对应具体的RenderObject,它是DecoratedBox.ConstrainedBox.Transform.Padding.Align等组件组 ...

  3. linux源码安装软件的一般方法

    rhel系统貌似安装不了xmgrace,配置的时候居然说要那个M*tif库.百度了一下,需要openmotif库,然后用root账户想要用yum安装一下这个库,搞了好久没搞懂.后面搞明白了,原因竟是因 ...

  4. logback为不同的包或类指定输出日志文件

    对日志分割的常见需求是,需要按不同的等级进行输出,这个的配置方式类似如下,在appender节点内添加内容 <appender name="FILE-INFO" class= ...

  5. MyBatis 查询的时候属性名和字段名不一致的问题

    目录 问题 解决方案:resultMap 问题 当我们数据库中的字段和实体类中的字段不一致的时候,查询会出问题 数据库字段是 pwd id name pwd 1 张三 123456 2 李四 1234 ...

  6. MySQL常用的数据类型和字段属性

    数据类型 数值 tinyint 十分小的数据 1个字节 smallint 较小的数据 2个字节 mediumint 中等大小的数据 3个字节 int 标准的整数 4个字节 常用 bigint 较大的数 ...

  7. C++:标准I/O流

    标准I/O对象:cin,cout,cerr,clog cout; //全局流对象 输出数据到显示器 cin; //cerr没有缓冲区 clog有缓冲区 cerr; //标准错误 输出数据到显示器 cl ...

  8. B树、B+树索引算法原理(下)

    B树.B+树索引算法原理(下) - codedump的网络日志 https://www.codedump.info/post/20200615-btree-2/

  9. 进程通信类型 管道是Linux支持的最初Unix IPC形式之一 命名管道 匿名管道

    管道 Linux环境进程间通信(一) https://www.ibm.com/developerworks/cn/linux/l-ipc/part1/index.html 管道及有名管道 郑彦兴200 ...

  10. setTimeout、Promise、Async/Await 的区别

    事件循环中分为宏任务队列和微任务队列其中setTimeout的回调函数放到宏任务队列里,等到执行栈清空以后执行promise.then里的回调函数会放到相应宏任务的微任务队列里,等宏任务里面的同步代码 ...