[NOIP提高组2018]货币系统
题目名称:货币系统
来源:2018年NOIP提高组
链接
博客链接
题目链接
题目内容
题目描述
在网友的国度中共有\(n\)种不同面额的货币,第\(i\)种货币的面额为\(a[i]\),你可以假设每一种货币都有无穷多张。为了方便,我们把货币种数为\(n\)、面额数组为\(a[1..n]\) 的货币系统记作\((n,a)\)。
在一个完善的货币系统中,每一个非负整数的金额\(x\)都应该可以被表示出,即对每一个非负整数\(x\),都存在\(n\)个非负整数\(t[i]\)满足\(a[i] \times t[i]\)的和为\(x\)。然而, 在网友的国度中,货币系统可能是不完善的,即可能存在金额\(x\)不能被该货币系统表示出。例如在货币系统\(n=3\),\(a=[2,5,9]\)中,金额\(1,3\)就无法被表示出来。
两个货币系统\((n,a)\) 和\((m,b)\) 是等价的,当且仅当对于任意非负整数\(x\),它要么均可以被两个货币系统表出,要么不能被其中任何一个表出。
现在网友们打算简化一下货币系统。他们希望找到一个货币系统\((m,b)\) ,满足\((m,b)\) 与原来的货币系统\((n,a)\) 等价,且\(m\)尽可能的小。他们希望你来协助完成这个艰巨的任务:找到最小的\(m\)。
题目大意
已知货币系统\((n,a)\),\(n\)表示有多少种面额,\(a\)是一个集合,各个元素表示各种面额的大小。
两个货币系统\((n,a)\) 和\((m,b)\)是等价的,当且仅当对于任意非负整数\(x\),它要么均可以被两个货币系统表出,要么不能被其中任何一个表出。
找到一个货币系统\((m,b)\) ,满足\((m,b)\) 与原来的货币系统\((n,a)\) 等价,且\(m\)尽可能的小。其中 \(b\in a\)。
格式
输入
输入文件的第一行包含一个整数\(T\),表示数据的组数。
接下来按照如下格式分别给出\(T\)组数据。 每组数据的第一行包含一个正整数\(n\)。接下来一行包含\(n\)个由空格隔开的正整数\(a[i]\)。
输出
输出文件共有\(T\)行,对于每组数据,输出一行一个正整数,表示所有与 \((n,a)\) 等价的货币系统 \((m,b)\) 中,最小的 \(m\)。
数据
样例
输入
2
4
3 19 10 6
5
11 29 13 19 17
输出
2
5
解释
在第一组数据中,货币系统\((2,[3,10])\) 和给出的货币系统\((n,a)\) 等价,并可以验证不存在\(m<2\) 的等价的货币系统,因此答案为\(2\)。 在第二组数据中,可以验证不存在$m<n $的等价的货币系统,因此答案为\(5\)。
数据范围
| 测试点 | n | a[i] | 测试点 | n | a[i] |
| 1 | =2 | ≤10000 | 11 | ≤13 | ≤16 |
|---|---|---|---|---|---|
| 2 | 12 | ||||
| 3 | 13 | ||||
| 4 | =3 | 14 | ≤25 | ≤40 | |
| 5 | 15 | ||||
| 6 | 16 | ||||
| 7 | =4 | 17 | ≤100 | ≤25000 | |
| 8 | 18 | ||||
| 9 | =5 | 19 | |||
| 10 | 20 |
对于\(100\%\)的数据,满足\(1≤T≤20,n,a[i]≥1\)。
提示
因为钱掉进了水里,所以这是一道水题。
题解
输入每种面额后,先将其从小到大排序。
引理
如果一个面额无法被比它小的面额凑出来,那么必须选,否则一定不选。
证明:前者很显然,因为这个数不可能被比其更大的数凑出来。
后者,因为这个数可以被其他数凑出来,那么需要这个数组成的数只需要凑成这个数的数就可以了。
于是我们按顺序做完全背包,如果发现没被前面的数背包得到就选,否则不选。
A(开始处理)-->B[是否被背包得到]
B-->|是|C[弃置]
B-->|否|D[选择该元素]
D-->E[在原来的基础上用该元素进行完全背包]
C-->F(进入下一次处理)
E-->F
//C++
#include<bits/locale_facets.h>
#include<memory.h>
#include<stdio.h>
using namespace std;
inline void output(long long value);
inline long long input();
short a[101],able[25001];
int main()
{
short T=input();
while(T--)
{
short n=input(),maximum=0;
short must=n;
for(short i=1;i<=n;i++)maximum=max(maximum,a[i]=input());
able[0]=true;
for(short i=1;i<=n;i++)
for(short j=a[i];j<=maximum;j++)
if(able[j-a[i]])able[j]++;
for(short i=1;i<=n;i++)
if(able[a[i]]>1)must--;
memset(able,0,50002);
output(must),putchar('\n');
}
return 0;
}
inline void output(long long o)
{
if(o<0)putchar('-'),o=-o;
if(o>=10)output(o/10);
putchar(o%10^'0');
}
inline long long input()
{
bool positive=true;
char now=getchar();
long long i=0;
for(;!isdigit(now);now=getchar())
if(now=='-')positive=!positive;
for(;isdigit(now);now=getchar())i=(i<<3)+(i<<1)+(now^'0');
return positive?i:-i;
}
[NOIP提高组2018]货币系统的更多相关文章
- NOIP提高组2018试题解析 目录
重磅来袭! 本蒟蒻准备挑战一下NOIP2018提高组的试题啦(怎么办 我猜我连10分都拿不了) 目录: Day1 1.铺设道路 讲解 得分:100 2.货币系统 讲解 3.赛道修建 讲解 ...
- NOIP提高组2018试题解析 Day1 T1 铺设道路 P5019
题目描述 春春是一名道路工程师,负责铺设一条长度为 nn 的道路. 铺设道路的主要工作是填平下陷的地表.整段道路可以看作是 nn 块首尾相连的区域,一开始,第 ii 块区域下陷的深度为 d_idi ...
- NOIP提高组2018 D1T3 【赛道修建】
颓了好几天,终于把这到题处理了一下. 话说,其实我考场上想出正解了,但是手残,算复杂度的时候多按了一个零,导致算出来是1亿多的复杂度,都不敢打...就把部分分都捡了一下... 题目描述: C 城将要举 ...
- 2018.12.30【NOIP提高组】模拟赛C组总结
2018.12.30[NOIP提高组]模拟赛C组总结 今天成功回归开始做比赛 感觉十分良(zhōng)好(chà). 统计数字(count.pas/c/cpp) 字符串的展开(expand.pas/c ...
- 2018.12.08【NOIP提高组】模拟B组总结(未完成)
2018.12.08[NOIP提高组]模拟B组总结 diyiti 保留道路 进化序列 B diyiti Description 给定n 根直的木棍,要从中选出6 根木棍,满足:能用这6 根木棍拼出一个 ...
- NOIP提高组初赛难题总结
NOIP提高组初赛难题总结 注:笔者开始写本文章时noip初赛新题型还未公布,故会含有一些比较老的内容,敬请谅解. 约定: 若无特殊说明,本文中未知数均为整数 [表达式] 表示:在表达式成立时它的值为 ...
- NOIP提高组2004 合并果子题解
NOIP提高组2004 合并果子题解 描述:在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消 ...
- 计蒜客 NOIP 提高组模拟竞赛第一试 补记
计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...
- 1043 方格取数 2000 noip 提高组
1043 方格取数 2000 noip 提高组 题目描述 Description 设有N*N的方格图(N<=10,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0.如下图所示(见样 ...
随机推荐
- python pillow 绘制图片
demo1 #coding=utf- from PIL import Image img = Image.,))###创建一个5*5的图片 pixTuple = (,,,)###三个参数依次为R,G, ...
- Android自定义view绘图
一.新建一个视图类,继承自View,重写OnDraw()函数,在函数内绘图 public class myView extends View {//新建一个视图类,继承自View myView(Con ...
- linux下安装apache和php和mysql
我的系统环境时ubuntu 18.04.3,为了ROS: 首先:安装下面一堆软件包: sudo apt install nginx nginx-doc fcgiwrap sudo apt instal ...
- onPageScroll的使用
1. 2.
- java关于Integer设置-128到127的静态缓存
今天在一个java群里,看到有个群友问到如下为什么第一个为true,第二个为false. System.out.println(Integer.valueOf("50")==Int ...
- DCL:管理用户
1. 管理用户 (1) 查询用户 MySQL把用户的数据存放在 "mysql" 数据库的 "user" 表中. SELECT * FROM user; (2) ...
- RK3288 修改ddr频率
转载请注明出处:https://www.cnblogs.com/lialong1st/p/10912334.html CPU:RK3288 系统:Android 5.1 RK3288 的 ddr 频率 ...
- Mysql -- The used SELECT statements have a different number of columns
这是因为使用union的两个SQL语句产生的记录的表结构不一致. 必须是结构完全一致的记录集合才可以使用UNION. 以上就是两个表的字段不一样,导致,所以大家可以检查下. 可以 将 select * ...
- osg::PagedLOD example
int main() { osg::ref_ptr<osgViewer::Viewer> viewer1 = new osgViewer::Viewer; osg::ref_ptr< ...
- osg qt 三维模型加载
osg::ref_ptr<osg::Node> OSG_Qt_::operateMatrix() { osg::ref_ptr<osg::Group> group = new ...