P5020 货币系统 题解
简要题意:
求一个长度最小的货币系统与给出的货币系统等价。求这个货币系统的长度。等价的定义详见题目,不再赘述。
本文可能用到一些集合论,请放心食用。
算法一
\(n=2\) 时,只需判断两个数的倍数关系。有倍数关系则答案为 \(1\),否则为 \(2\).
时间复杂度:\(O(T \times n)\).
实际得分:\(15pts\).
算法二
\(n=3\) 时,首先,如果两个数都是另一个数的倍数,那么答案为 \(1\).
否则,如果仍存在倍数关系,则答案为 \(2\).
其余的情况,只需要考虑,最小的数和次小的数能否表示出最大的数。
能则为 \(2\),否则为 \(3\).
这里有很多种方法判断。比如:
暴力,用桶直接来,\(O(\max a_i)\).
考虑解方程,用 \(\texttt{exgcd}\) 写,\(O(\log \max a_i)\).
总之,时间复杂度为 \(O(T \times n \times (\max a_i))\). (无需优化,因为没有必要)
实际得分:\(30pts\).
算法三
首先,假设给出 \(S\),答案为 \(T\). 则必有:
\]
下面来证明这个结论。
如果 \(T \not \in S\),则考虑取出 \(x = \min (i \in S)\),\(y = \min(i \in T)\).
如果 \(x<y\),则 \(x\) 无法被表示。
如果 \(y>x\),则 \(y\) 无法被表示。
如果 \(x=y\),那么不断递归下去,得证。
所以,我们只需要在给出的货币系统中寻找答案即可。
这里我们枚举选的答案,然后一一验证。
时间复杂度:\(O(2^n \times n \times (\max a_i) \times T)\),可以通过。
实际得分:\(65pts\).
算法四
注: \(n = 25\),本人没有想到什么可以 \(O(2^n \times T)\) 过掉的算法,因此这一档部分分可能是用来给选手瞎搞的。???
你发现不需要一一枚举。首先你排序一下。
你只要用当前已有的数,判断当前正在决策的这个数能否被表示出。
能,那么说明这个数没有必要,把它抛弃。
否则,肯定要选。只是因为,\(>\) 它的数表示不出,而 \(<\) 也表示不出,只有它自己能表示自己,所以必须选。
那么,这样我们可以唯一确定一个数是否被选。(排序后从小到大选)
如何判断?
我们发现,每次新加入一个数 \(x\) ,我们需要维护能判断出的桶。
此时,可以在原有的桶上,对每个能表示出的数 \(k\),把 \(k+x , k+2x,k+3x \cdots k+ \infty x\) 全部标为可以判断。这是显然的。
至于 \(\infty\) 的上限,只要标到 \(\max a_i\) 即可,因为后面的数没有用了。
时间复杂度:\(O(n \times T \times (\max a_i))\).
实际得分:\(100pts\).
#pragma GCC optimize(2)
#include<bits/stdc++.h>
using namespace std;
const int N=5e4+1;
inline int read(){char ch=getchar();int f=1;while(ch<'0' || ch>'9') {if(ch=='-') f=-f; ch=getchar();}
int x=0;while(ch>='0' && ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();return x*f;}
int T,n,a[N];
int cnt=0;
int maxi; bool h[N];
int main(){
T=read(); while(T--) {
n=read(); maxi=0; cnt=0;
memset(h,0,sizeof(h)); //初始化
for(int i=1;i<=n;i++) a[i]=read(),maxi=max(maxi,a[i]);
sort(a+1,a+1+n); //排序
for(int i=1;i<=n;i++)
if(!h[a[i]]) { //不能被表示
h[a[i]]=1; cnt++;
for(int j=1;j<=maxi;j++)
if(h[j]) {
for(int k=a[i];j+k<=maxi;k+=a[i])
h[j+k]=1;
} //维护能被表示的桶
} printf("%d\n",cnt);
}
return 0;
}
P5020 货币系统 题解的更多相关文章
- 洛谷P5020 货币系统 题解 模拟
题目链接:https://www.luogu.org/problem/P5020 这道题目是一道模拟题,但是又有一点多重背包的思想在里面. 首先我们定义一个 vis[i] 来表示和为 i 的情况在之前 ...
- 洛谷 p5020 货币系统 题解
传送门 一个手动枚举能过一半点而且基本靠数学的题目(然而我考试的时候只有25分) 读清题目后发现就是凑数嘛,.... 对啊,就是凑数,怎么凑是重点啊.. 于是就绝望了一小时手动枚举n从1到5的情况 吐 ...
- P5020 货币系统
P5020 货币系统 题解 仔细分析... 这道题其实就是求所给数组中有多少个数字不能被该数组中的数字自由组合表示出来 比如样例1 3,10 不能被该集合里的数字表示出来,所以他们组成目标集合 6=3 ...
- 背包 || NOIP 2018 D1 T2 || Luogu P5020 货币系统
题面:P5020 货币系统 题解: 显然要求的货币系统是当前货币系统的子集时答案会更优,于是考虑从当前货币系统中删数 一个大数如果能被其他小数表示出来,它就可以去掉 把数据排个序去个重,然后直接背包 ...
- 洛谷 P5020 货币系统
题目描述 在网友的国度中共有$ n $种不同面额的货币,第 i种货币的面额为 \(a[i]\),你可以假设每一种货币都有无穷多张.为了方便,我们把货币种数为\(n\).面额数组为 \(a[1..n]\ ...
- Luogu P5020 货币系统
Luogu P5020 货币系统 先把$a$数组排一下序. 从最小的数开始选,显然最小这个数必须选,然后利用完全背包的思想,从$a_i$到最大值筛选一遍,将可以组成的打上标记. 在判断后面的数字时,如 ...
- 【数学】【背包】【NOIP2018】P5020 货币系统
传送门 Description 在网友的国度中共有 \(n\) 种不同面额的货币,第 \(i\) 种货币的面额为 \(a[i]\),你可以假设每一种货币都有无穷多张.为了方便,我们把货币种数为 \(n ...
- [NOIp2018] luogu P5020 货币系统
还在补暑假作业. 题目描述 你有一个由 NNN 种面值的货币组成的货币系统.定义两个货币系统等价,当且仅当 ∀x∈N∗\forall x\in\N^*∀x∈N∗ 要么同时能被两个货币系统表示,要么同时 ...
- NOIp2018 TG day1 T2暨洛谷P5020 货币系统:题解
题目链接:https://www.luogu.org/problemnew/show/P5020 这道题感觉比较水啊,身为普及组蒟蒻都不费力的做出来了,而且数据范围应该还能大一些,n起码几万几十万都不 ...
随机推荐
- Book. Effective C++ item2-尽量使用const, enum, inline替换#define
##常规变量 c++里面的#define后面的定义部分,是不算代码的一部分的.所以如果你使用#define: #define ASPECT_RATIO 1.653 你希望这个代号ASPECT RATI ...
- github里的readme.md
在github里如何写readme.md https://www.cnblogs.com/guchunli/p/6371040.html----------------------> READM ...
- 【阿里云IoT+YF3300】16.云端一体化,天猫精灵操控YF3300
“你好天猫精灵”,“主人有什么吩咐”,“打开灯”,“好的,灯已打开”.对于这样的对话应该大多数人都很熟悉,这就是智能家居的缩影.对于现在市面上层出不穷的智能家居系统,功能越来越繁杂,可是因为开发难度高 ...
- ORB-SLAM2 运行 —— ROS + Android 手机摄像头
转载请注明出处,谢谢 原创作者:Mingrui 原创链接:https://www.cnblogs.com/MingruiYu/p/12404730.html 本文要点: ROS 配置安装 解决 sud ...
- 从0开发3D引擎(十):使用领域驱动设计,从最小3D程序中提炼引擎(上)
目录 上一篇博文 下一篇博文 前置知识 回顾上文 最小3D程序完整代码地址 通用语言 将会在本文解决的不足之处 本文流程 解释本文使用的领域驱动设计的一些概念 本文的领域驱动设计选型 设计 引擎名 识 ...
- 用vue开发一个公众号商城SPA——1.前期准备和写页面
使用vue开发公众号商城 第1篇记录项目准备.搭建,写页面遇到第问题以及总结,持续更新 公司最近接了个商城项目,包括PC端商城.微信公众号网页商城.后台管理系统.这几天在做微信公众号商城,又新接触了很 ...
- Python基础--动态传参
形参的顺序: 位置 *arg 默认值 **args ps:可以随便搭配,但是*和**以及默认值的位置顺序不能变 *,** 形参:聚合 位置参数* >>元祖 关键字** > ...
- 题解-[HNOI2001]遥控赛车比赛
题解-[HNOI2001]遥控赛车比赛 前置知识:记忆化搜索.\(\texttt{Bfs}\). 参考资料 https://www.luogu.com.cn/blog/CYJian/solution- ...
- 判断某个点是否在某个view上
-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { UITouch *touch = [touches anyObjec ...
- 【vue】---- 图片懒加载
1.作用 在图片较多的页面中,页面加载性能较差.使用图片懒加载可以让图片出现在可视区域时再进行加载,从而提高用户体验. 2.原理 设置img标签的src属性为空或统一的图片路径(如加载中样式),监听页 ...