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


相关推荐

  • Python面向对象三大特征

    Python面向对象三大特征面向对象三大特征 封装 将属性和方法包装到类对象中 在方法内部对属性进行操作 在类对象外部调用方法 继承 多继承 方法重写多态 即便不知道一个变量所引用的对象是什么类型 仍然可以使用这个变量调用方法 在运行过程中根据变量所引用的对象类型 动态决定调用那个对象中的方法 动态语言 关注对象的行为静态语言 继承 方法重写 父类引用指向子类对象 object 类所有类的父类 new 创建对象 init 初始化对象 str 返回对象的描述

    2026年3月18日
    1
  • gitlab+jenkins+docker 实现自动化部署(一)

    gitlab+jenkins+docker 实现自动化部署(一)gitlab jenkins docker 实现自动化部署超详细 爆肝

    2026年3月19日
    2
  • Linux下安装RabbitMQ

    Linux下安装RabbitMQ一、RabbitMQ介绍RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python、Ruby、.NET、Java、JMS、C、PHP、ActionScript、XMPP、STOMP等,支持AJAX。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。AMQP,即AdvancedMessageQ…

    2025年8月20日
    3
  • oracle查看视图定义语句_oracle视图总结

    oracle查看视图定义语句_oracle视图总结视图简介 视图是基于一个表或多个表或视图的逻辑表 本身不包含数据 通过它可以对表里面的数据进行查询和修改 视图基于的表称为基表 视图是存储在数据字典里的一条 select 语句 通过创建视图可以提取数据的逻辑上的集合或组合 视图的优点 1 对数据库的访问 因为视图可以有选择性的选取数据库里的一部分 2 用户通过简单的查询可以从复杂查询中得到结果 3 维护数据的独立性 试图可从多个表检索数据 4 对于

    2026年3月18日
    2
  • 搭建DNS服务器的那些知识「建议收藏」

    搭建DNS服务器的那些知识「建议收藏」一、DNS服务概述:1.什么是DNS?DNS(DomainNameSystem)域名系统,在TCP/IP网络中有非常重要的地位,能够提供域名与IP地址的解析服务,而不用去记住能够被机器直接读取的IP数串。通过域名,最终得到该域名对应的IP地址的过程叫做域名解析。DNS协议运行在UDP协议之上,使用端口53号。2.什么是域、域名?域(domain)是计算机网络的一种形式,其中所有用户账户,计算机,打印机和其他安全主体都在位于称为域控制器的一个或多个中央计算机集群上的中央数据库中注册。

    2025年9月16日
    6
  • WinForm学习

    WinForm学习C#学习

    2022年10月7日
    5

发表回复

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

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