组成aim的方法数3(有限张,重复牌视为相同)

2024-05-26 01:36

本文主要是介绍组成aim的方法数3(有限张,重复牌视为相同),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述:arr是货币数组,其中的值都是正数,再给定一个正数aim,每个值都认为是一张货币,认为值相同的货币没有任何不同,返回组成aim的方法数。例如,arr=[1,2,1,1,2,1,2],aim=4,方法,1+1+1+1,1+1+2,2+2,一共3种方法,所以返回3。

way:

//将货币按面值,张数统计出来放到Info中的2个vector中
//coins面值数组,正数且去重
//zhangs 每种面值对应的张数
//arr[index...]所有的面值,每一个面值都可以选择有限张数,组成rest元的方法数。
#include<iostream>
#include<vector>
#include<map>
using namespace std;struct Info
{vector<int>coins;vector<int>zhangs;Info(vector<int>coins, vector<int>zhangs){this->coins=coins;this->zhangs=zhangs;}
};Info getInfo(vector<int>arr)
{int n=arr.size();map<int,int>mp;for(int i=0; i<n; i++){mp[arr[i]]++;}vector<int>coins;vector<int>zhangs;for(auto pa:mp){coins.push_back(pa.first);zhangs.push_back(pa.second);}return Info(coins, zhangs);
}//coins面值数组,正数且去重
//zhangs 每种面值对应的张数
//arr[index...]所有的面值,每一个面值都可以选择有限张数,组成rest元的方法数。
int process(vector<int>coins, vector<int>zhangs, int index, int rest)
{if(index==coins.size()){return rest==0?1:0;}int ways=0;for(int zhang=0; (zhang<=zhangs[index])&&(rest-zhang*coins[index]>=0); zhang++){ways+=process(coins, zhangs, index+1, rest-zhang*coins[index]);}return ways;
}int coinWay(vector<int>arr, int aim)
{//将货币按面值,张数统计出来放到Info中的2个vector中Info info = getInfo(arr);return process(info.coins, info.zhangs, 0, aim);
}

way2:dp版

int dpWay(vector<int>arr, int aim)
{//将货币按面值,张数统计出来放到Info中的2个vector中Info info = getInfo(arr);vector<int>coins=info.coins;vector<int>zhangs=info.zhangs;int N=coins.size();vector<vector<int>>dp(N+1,vector<int>(aim+1));dp[N][0]=1;for(int index=N-1; index>=0; index--){for(int rest=0; rest<=aim; rest++){int ways=0;for(int zhang=0; (zhang<=zhangs[index])&&(rest-zhang*coins[index]>=0); zhang++){ways+=dp[index+1][rest-zhang*coins[index]];}dp[index][rest]=ways;}}return dp[0][aim];
}

这篇关于组成aim的方法数3(有限张,重复牌视为相同)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1003190

相关文章

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

电脑不小心删除的文件怎么恢复?4个必备恢复方法!

“刚刚在对电脑里的某些垃圾文件进行清理时,我一不小心误删了比较重要的数据。这些误删的数据还有机会恢复吗?希望大家帮帮我,非常感谢!” 在这个数字化飞速发展的时代,电脑早已成为我们日常生活和工作中不可或缺的一部分。然而,就像生活中的小插曲一样,有时我们可能会在不经意间犯下一些小错误,比如不小心删除了重要的文件。 当那份文件消失在眼前,仿佛被时间吞噬,我们不禁会心生焦虑。但别担心,就像每个问题

邮件群发推送的方法技巧?有哪些注意事项?

邮件群发推送的策略如何实现?邮件推送怎么评估效果? 电子邮件营销是现代企业进行推广和沟通的重要工具。有效的邮件群发推送不仅能提高客户参与度,还能促进销售增长。AokSend将探讨一些关键的邮件群发推送方法和技巧,以帮助企业优化其邮件营销策略。 邮件群发推送:目标受众 了解他们的需求、兴趣和行为习惯有助于你设计出更具吸引力和相关性的邮件内容。通过收集和分析数据,创建详细的客户画像,可以更精

上采样(upsample)的方法

上采样(upsample)的方法   在神经网络中,扩大特征图的方法,即upsample/上采样的方法   1)unpooling:恢复max的位置,其余部分补零   2)deconvolution(反卷积):先对input补零,再conv   3)插值方法,双线性插值等;   4)扩张卷积,dilated conv;

LeetCode--220 存在重复元素 III

题目 给定一个整数数组,判断数组中是否有两个不同的索引 i 和 j,使得 nums [i] 和 nums [j] 的差的绝对值最大为 t,并且 i 和 j 之间的差的绝对值最大为 ķ。 示例 示例 1:输入: nums = [1,2,3,1], k = 3, t = 0输出: true示例 2:输入: nums = [1,0,1,1], k = 1, t = 2输出: true示例

LeetCode--217 存在重复元素

题目 给定一个整数数组,判断是否存在重复元素。如果任何值在数组中出现至少两次,函数返回 true。如果数组中每个元素都不相同,则返回 false。 示例 示例 1:输入: [1,2,3,1]输出: true示例 2:输入: [1,2,3,4]输出: false示例 3:输入: [1,1,1,3,3,4,3,2,4,2]输出: true class Solution {p

axios全局封装AbortController取消重复请求

为什么? 问题:为什么axios要配置AbortController?防抖节流不行吗? 分析: 防抖节流本质上是用延时器来操作请求的。防抖是判断延时器是否存在,如果存在,清除延时器,重新开启一个延时器,只执行最后一次请求。节流呢,是判断延时器是否存在,如果存在,直接return掉,直到执行完这个延时器。事实上,这些体验感都不算友好,因为对于用户来说,得等一些时间,尤其是首次请求,不是那么流畅

青龙面板部署通用教程,含服务器、路由器、X86等部署方法

1. 拉取镜像/更新镜像 docker pull whyour/qinglong:latest 2. 删除镜像 docker rmi whyour/qinglong:latest 3. 启动容器 普通服务器 docker run -dit \-v $PWD/ql/config:/ql/config \-v $PWD/ql/log:/ql/log \-v $PWD/ql/db: