当前位置: 首页 > news >正文

AcWing算法提高课-1.3.6货币系统

宣传一下算法提高课整理 <—

CSDN个人主页:更好的阅读体验 <—

f4e0159841ab450d861dde9e8fb5ba0d.gif

本题链接(AcWing)

点这里

题目描述

给你一个n种面值的货币系统,求组成面值为m的货币有多少种方案。

输入格式

第一行,包含两个整数n和m。

接下来n行,每行包含一个整数,表示一种货币的面值。

输出格式

共一行,包含一个整数,表示方案数。

数据范围

n ≤ 15 , m ≤ 3000 n \le 15, m \le 3000 n15,m3000

输入样例:

3 10
1
2
5

输出样例:

10

思路

本题为DP问题,可以使用闫氏DP分析法解题。

DP:

  • 将组成面值为 m m m 的货币看作背包容量
  • n n n 种价格的货币看做有该体积的物品
  • 状态计算:
    ······ f [ 0 ] ← 1 f[0] \leftarrow 1 f[0]1
    ······ f [ j ] ← f [ j − v ] f[j] \leftarrow f[j - v] f[j]f[jv]

注意要开 long long


A C AC AC C o d e Code Code:

C + + C++ C++

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;typedef long long LL;const LL N = 3010;LL n, m;
LL f[N];int main()
{scanf("%lld%lld", &n, &m);f[0] = 1;LL v;for (LL i = 1; i <= n; i ++ ){scanf("%lld", &v);for (LL j = v; j <= m; j ++ )f[j] += f[j - v];}printf("%lld\n", f[m]);return 0;
}

228aa7bed3e021faf24cf8560d3e47bb.gif

最后,如果觉得对您有帮助的话,点个赞再走吧!

http://www.lryc.cn/news/68232.html

相关文章:

  • vue3回到上一个路由页面
  • Linux三种网络模式 | 仅主机、桥接、NAT
  • 数据库设计与前端框架
  • 技术探秘:揭秘Bean Factory与FactoryBean的区别!
  • MD-MTSP:遗传算法GA求解多仓库多旅行商问题(提供MATLAB代码,可以修改旅行商个数及起点)
  • 技术面试的终极指南:助你取得成功的关键步骤
  • Nautilus Chain 测试网第二阶段,推出忠诚度计划及广泛空投
  • Python爬虫(三):BeautifulSoup库
  • Python使用CV2库捕获、播放和保存摄像头视频
  • [数据结构 -- C语言] 栈(Stack)
  • 【我的C++入门之旅】(上)
  • dcdc降压电路原理及仿真
  • 搭建Redis主从集群+哨兵+代理predixy
  • Syncthing文件同步 - 免费搭建开源的文件自动同步服务器并公网远程访问【私人云盘】
  • SQL——索引
  • Java代码组成部分
  • vue2和vue3有啥区别,vue3的优点有哪些?
  • 就业内推 | 上市公司招网工,最高25k*14薪,六险一金
  • 低代码让开发变得不再复杂
  • 【前端客栈】使用CSS实现畅销书排行榜页面
  • 【周末闲谈】超越ChatGPT?科大讯飞星火认知大模型
  • 第N2周:中文文本分类-Pytorch实现
  • Salesforce许可证和版本有什么区别,购买帐号时应该如何选择?
  • 接口测试怎么做?全网最详细从接口测试到接口自动化详解,看这篇就够了...
  • DataStore入门及在项目中的使用
  • 用Python爬取中国各省GDP数据
  • 深度学习-第T5周——运动鞋品牌识别
  • 自媒体的孔雀效应:插根鸡毛还是专业才华?
  • Linux系统优化
  • Java笔记_22(反射和动态代理)