hdu 2069 普通母函数 +dp

2023-10-23 15:38
文章标签 函数 dp hdu 普通 2069

本文主要是介绍hdu 2069 普通母函数 +dp,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目传送门:点击打开链接

一开始做题并没有想到Your program should be able to handle up to 100 coins.这句话什么意思,也没有当回事。。但是wa几次,我就感觉只是套模版应该是不对的,但是又找不到,后来我在论坛上看到写着 总的硬币个数不能超过100,才知道有条件限制。但是接下来该怎么利用这条件呢?母函数模版只是能得出最后的结果,并不能求出m个硬币凑成的这个n价值的方法数,所以我们利用母函数的求解问题的思路,用二维数组c1[][]来代替c1[],c1[i][j]  i其实与模版中的i含义一样(表示凑成i的价值),那么j 代表用了j个硬币凑成i  所以c1[i][j]代表 j个硬币凑成i的方法个数。所以在求的价值为n的时候,我们只要判断硬币个数是否大与100就可以了。这不懂的话可以看一下代码。。(注释的不用看)后面的注释为个别数据。

#include <iostream>
#include <cstring>
using namespace std;
typedef long long ll;
int f[]={0,1,5,10,25,50};
int c1[300][110],c2[300][110];
int n;
void solve()
{memset(c1,0,sizeof(c1));memcpy(&c2,&c1,sizeof(c1));c1[0][0]=1;for(int i=1;i<=n&&i<=100;++i)c1[i][i]=1;for(int i=2;i<=5;++i){for(int j=0;j<=n;++j){//if(c1[j][0])//{for(int k=0;k+j<=n;k+=f[i]){for(int kk=0;k/f[i]+kk<=100;++kk)//判断条件{if(c1[j][kk]){c2[j+k][kk+k/f[i]]+=c1[j][kk];//if(j+k==115)//  cout<<j<<" "<<kk<<' '<<c1[j][kk]<<endl;}}}}memcpy(&c1,&c2,sizeof(c2));memset(c2,0,sizeof(c2));}int ans=0;for(int i=0;i<=100;++i)ans+=c1[n][i];cout<<ans<<endl;// cout<<c1[n][0]<<endl;
}
int main(int argc, const char * argv[])
{while(cin>>n){solve();}return 0;
}
//n      ans
//0      1
//250   3830//110   380//115   430//100   292//101   291

Coin Change

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 18203    Accepted Submission(s): 6268


Problem Description
Suppose there are 5 types of coins: 50-cent, 25-cent, 10-cent, 5-cent, and 1-cent. We want to make changes with these coins for a given amount of money.

For example, if we have 11 cents, then we can make changes with one 10-cent coin and one 1-cent coin, or two 5-cent coins and one 1-cent coin, or one 5-cent coin and six 1-cent coins, or eleven 1-cent coins. So there are four ways of making changes for 11 cents with the above coins. Note that we count that there is one way of making change for zero cent.

Write a program to find the total number of different ways of making changes for any amount of money in cents. Your program should be able to handle up to 100 coins.

Input
The input file contains any number of lines, each one consisting of a number ( ≤250 ) for the amount of money in cents.

Output
For each input line, output a line containing the number of different ways of making changes with the above 5 types of coins.

Sample Input
  
11 26

Sample Output
  
4 13


这篇关于hdu 2069 普通母函数 +dp的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

什么是 Ubuntu LTS?Ubuntu LTS和普通版本区别对比

《什么是UbuntuLTS?UbuntuLTS和普通版本区别对比》UbuntuLTS是Ubuntu操作系统的一个特殊版本,旨在提供更长时间的支持和稳定性,与常规的Ubuntu版本相比,LTS版... 如果你正打算安装 Ubuntu 系统,可能会被「LTS 版本」和「普通版本」给搞得一头雾水吧?尤其是对于刚入

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

hdu4826(三维DP)

这是一个百度之星的资格赛第四题 题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1004&cid=500 题意:从左上角的点到右上角的点,每个点只能走一遍,走的方向有三个:向上,向下,向右,求最大值。 咋一看像搜索题,先暴搜,TLE,然后剪枝,还是TLE.然后我就改方法,用DP来做,这题和普通dp相比,多个个向上

hdu1011(背包树形DP)

没有完全理解这题, m个人,攻打一个map,map的入口是1,在攻打某个结点之前要先攻打其他一个结点 dp[i][j]表示m个人攻打以第i个结点为根节点的子树得到的最优解 状态转移dp[i][ j ] = max(dp[i][j], dp[i][k]+dp[t][j-k]),其中t是i结点的子节点 代码如下: #include<iostream>#include<algorithm

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>