acwing-532货币系统(最小独立集+01背包)「建议收藏」

acwing-532货币系统(最小独立集+01背包)「建议收藏」在网友的国度中共有 n 种不同面额的货币,第 i 种货币的面额为 a[i],你可以假设每一种货币都有无穷多张。为了方便,我们把货币种数为 n、面额数组为 a[1…n] 的货币系统记作 (n,a)。在一个完善的货币系统中,每一个非负整数的金额 x 都应该可以被表示出,即对每一个非负整数 x,都存在 n 个非负整数 t[i] 满足 a[i]×t[i] 的和为 x。然而,在网友的国度中,货币系统可能是不完善的,即可能存在金额 x 不能被该货币系统表示出。例如在货币系统 n=3, a=[2,5,9] 中,金

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

在网友的国度中共有 n 种不同面额的货币,第 i 种货币的面额为 a[i],你可以假设每一种货币都有无穷多张。

为了方便,我们把货币种数为 n、面额数组为 a[1…n] 的货币系统记作 (n,a)。

在一个完善的货币系统中,每一个非负整数的金额 x 都应该可以被表示出,即对每一个非负整数 x,都存在 n 个非负整数 t[i] 满足 a[i]×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。

输入格式
输入文件的第一行包含一个整数 T,表示数据的组数。

接下来按照如下格式分别给出 T 组数据。

每组数据的第一行包含一个正整数 n。

接下来一行包含 n 个由空格隔开的正整数 a[i]。

输出格式
输出文件共有 T 行,对于每组数据,输出一行一个正整数,表示所有与 (n,a) 等价的货币系统 (m,b) 中,最小的 m。

数据范围
1≤n≤100,
1≤a[i]≤25000,
1≤T≤20
输入样例:
2
4
3 19 10 6
5
11 29 13 19 17
输出样例:
2
5

题解
如果一个货币能够被其他货币拼凑出来,那么这个货币可以被丢弃,这启发我们使用恰好等于版的01背包问题

#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
const int INF = 0x3f3f3f3f;
int f[N],a[N];
int main(){ 
   
    int n,m,T;
    cin>>T;
    while(T--){ 
   
        cin>>n;
        memset(f,-INF,sizeof f);
        f[0] = 0;
        int Max = 0;
        for(int i = 0;i < n;i ++)cin>>a[i],Max = max(Max,a[i]);
        sort(a,a + n);
        int res = n;
        for(int i = 0;i < n;i ++){ 
   
            if(f[a[i]] == a[i])res --;
            for(int j = a[i];j <= Max;j ++){ 
   
                f[j] = max(f[j],f[j - a[i]] + a[i]);
            }
        }
        cout<<res<<endl;
    }
    return 0;
}

  1. 利用方案数也可以解决
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
const int INF = 0x3f3f3f3f;
int f[N],a[N];
int main(){ 
   
    int n,m,T;
    cin>>T;
    while(T--){ 
   
        cin>>n;
        memset(f,0,sizeof f);
        f[0] = 1;
        int Max = 0;
        for(int i = 0;i < n;i ++)cin>>a[i],Max = max(Max,a[i]);
        sort(a,a + n);
        int res = 0;
        for(int i = 0;i < n;i ++){ 
   
            if(!f[a[i]])res ++;
            for(int j = a[i];j <= Max;j ++){ 
   
                f[j] += f[j - a[i]];
            }
        }
        cout<<res<<endl;
    }
    return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168697.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月8日 下午5:00
下一篇 2022年8月8日 下午5:16


相关推荐

  • pycharm激活成功教程的两种方式

    pycharm激活成功教程的两种方式Pycharm激活成功教程方式1: 0x1,安装0x2,调整时间到2038年。0x3,申请30天试用0x4,退出pycharm0x5,时间调整回来。Pycharm激活成功教程方式2:安装完软件后,启动,在要求输入注册码的界面(菜单栏⇒help⇒register)选择“Licenseserver”输入“http:/

    2022年8月29日
    7
  • iOS10 iPhone5 10.3.3每次越狱后要做的事「建议收藏」

    iOS10 iPhone5 10.3.3每次越狱后要做的事「建议收藏」由于经常没电关机,越狱失效,就需要经常再越狱。越狱后要:1.越狱设备安装“AFC2”补丁。https://www.i4.cn/news_detail_1623.html2.安装AppSynchttps://www.i4.cn/news_detail_13094.html3.openssh安装完不管用需要重启,再越狱,afc2更改—从新安装4.电脑命令行连接设备sshroot@192.168.199.110alpine5.Clutc…

    2022年6月12日
    44
  • lc5找回windows账户信息

    lc5找回windows账户信息  示例:利用lc5获取winserver2003的账户信息。  1. 安装lc5。百度搜索lc5下载安装包,并将lc5安装到winserver2003虚拟机上。  2. 可以用一下命令创建几个待测试的账号    命令行:netusernamepassword/add创建用户           netusername…

    2022年7月24日
    9
  • python的数据处理_基于python的数据处理

    python的数据处理_基于python的数据处理源起:1.我要做交叉验证,需要每个训练集和测试集都保持相同的样本分布比例,直接用sklearn提供的KFold并不能满足这个需求。2.将生成的交叉验证数据集保存成CSV文件,而不是直接用sklearn训练分类模型。3.在编码过程中有一的误区需要注意:这个sklearn官方给出的文档>>>importnumpyasnp>>>fromsklearn.mo…

    2025年11月19日
    4
  • DDD领域驱动设计详解

    DDD领域驱动设计详解DDD 领域驱动设计 1 领域驱动设计 1 1 什么是领域驱动设计 1 2 为什么用领域驱动设计 2 DDD 核心知识体系 2 1DDD 核心概念 2 2DDD 战略战术设计 2 2 1DDD 战略设计 2 2 1DDD 战术设计 3 DDD 微服务架构模型 3 1 基本架构 3 1 1DDD 分层架构 3 1 1 六边形理论 3 1 1CQRS 架构设计 3 2 代码结构 3 3 服务调用 1 领域驱动设计 1 1 什么是领域驱动设计领域驱动设计 DomainDriven 是一种从系统分析到软件建模的一套方法论

    2026年3月19日
    2
  • 设置pycharm的python解释器_pycharm安装后无解释器

    设置pycharm的python解释器_pycharm安装后无解释器选择File->setting(快捷键ctrl+alt+s)弹出下图界面,选择左边红色圈,ProjectPython->ProjectInterpreter再单击右边设置图标弹出下图点击SystemInterpreter再点击右边方框,弹出路径选择框,选择安装的python.exe路径…

    2022年8月28日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号