九度oj 题目1209:最小邮票数
- 题目描述:
-
有若干张邮票,要求从中选取最少的邮票张数凑成一个给定的总值。
如,有1分,3分,3分,3分,4分五张邮票,要求凑成10分,则使用3张邮票:3分、3分、4分即可。
- 输入:
-
有多组数据,对于每组数据,首先是要求凑成的邮票总值M,M<100。然后是一个数N,N〈20,表示有N张邮票。接下来是N个正整数,分别表示这N张邮票的面值,且以升序排列。
- 输出:
-
对于每组数据,能够凑成总值M的最少邮票张数。若无解,输出0。
- 样例输入:
-
10
5
1 3 3 3 4
- 样例输出:
-
3
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#define MAX 22 int ticket[MAX];
int flag[MAX];
int min; void dfs(int target, int end, int cnt) {
if(cnt > min) {
return;
}
if(target == ) {
if(cnt < min) {
min = cnt;
return;
}
}
for(int i = end-; i >= ; i--) {
if(flag[i] == && ticket[i] <= target) {
flag[i] = ;
dfs(target - ticket[i], i,cnt + );
flag[i] = ;
}
}
} int main()
{ int n, m;
while(scanf("%d",&n) != EOF) { scanf("%d",&m);
for(int i = ; i < m; i++) {
scanf("%d",&ticket[i]);
}
memset(flag,,sizeof(flag));
min = m+;
dfs(n,m,);
if(min != m+) {
printf("%d\n",min);
}
else {
puts("");
} }
return ;
}这道题考虑的是回溯法,并用类似天平的思想,从大到小依次加砝码。如果不行,全都移除,从下一个大的开始继续加。
这道题也能用动态规划求解,时间要稍长一些
写了一个简单的代码:
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <cmath>
#define MAX 22
#define inf 1000002
using namespace std; int ticket[MAX];
int dp[MAX][]; int main()
{
//freopen("input.txt","r",stdin);
int n, m;
while(scanf("%d",&n) != EOF) { scanf("%d",&m);
for(int i = ; i < m; i++) {
scanf("%d",&ticket[i]);
} for(int r = ; r <= n; r++) {
for(int i = ; i < m; i++) {
dp[i][r] = inf;
}
} for(int i = ; i <=n; i++) {
dp[i][] = ;
}
dp[][ticket[]] = ;
for(int r = ; r <= n; r++) {
for(int i = ; i < m; i++) {
if(r >= ticket[i]) {
dp[i][r] = min(dp[i-][r],dp[i-][r-ticket[i]] + );
}
else {
dp[i][r] = dp[i-][r];
}
}
} if(dp[m-][n] != inf) {
printf("%d\n", dp[m-][n]);
}
else {
puts("");
} }
return ;
}主要的难点在于初始化和转移方程
九度oj 题目1209:最小邮票数的更多相关文章
- 九度oj题目&吉大考研11年机试题全解
九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ...
- 九度oj 题目1007:奥运排序问题
九度oj 题目1007:奥运排序问题 恢复 题目描述: 按要求,给国家进行排名. 输入: 有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...
- 九度OJ 题目1384:二维数组中的查找
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
- hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- 九度OJ 1502 最大值最小化(JAVA)
题目1502:最大值最小化(二分答案) 九度OJ Java import java.util.Scanner; public class Main { public static int max(in ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ题目1105:字符串的反码
tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...
- 九度oj题目1009:二叉搜索树
题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...
- 九度oj题目1002:Grading
//不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...
随机推荐
- CF1025C Plasticine zebra
思路: 不要被骗了,这个操作实际上tm是在循环移位. 实现: #include <bits/stdc++.h> using namespace std; int main() { stri ...
- uvm_subscriber——告诉她我们来过
Subscribers are basically listeners of an analysis port. They subscribe to a broadcaster and receive ...
- PHP小数处理常用函数
1.php保留两位小数并且四舍五入 $num = 123213.666666; echo sprintf("%.2f", $num); // 123213.67echo round ...
- XPath基本使用
一.简介 1.什么是XPath 1)XPath是W3C的一个标准 2)XPath 是一门在 XML 文档中查找信息的语言. 3)XPath 用于在 XML 文档中通过元素和属性进行导航. 4)XPa ...
- EL1008E: Property or field 'timestamp' cannot be found on object of type 'java.util.HashMap
2018-06-22 09:50:19.488 INFO 20096 --- [nio-8081-exec-2] o.a.c.c.C.[Tomcat].[localhost].[/] : ...
- 插值(scipy.interpolate)
https://docs.scipy.org/doc/scipy/reference/interpolate.html#module-scipy.interpolate https://stackov ...
- MIPS汇编程序设计——四则运算计算器
实验目的 运用简单的MIPS实现一个能够整数加减乘除的计算器,同时使自己更加熟悉这些指令吧 MIPS代码 #sample example 'a small calculater’ # data sec ...
- 在idea下创建maven
之前一直用eclipse,现在要用idea写一个安装过程玩玩 一:New Project 二:选择maven,在project SDK上选择你安装的jdk,默认安装在c:/Program Files ...
- Gradle环境下导出Swagger为PDF
更多精彩博文,欢迎访问我的个人博客 说明 我个人是一直使用Swagger作为接口文档的说明的.但是由于在一些情况下,接口文档说明需要以文件的形式交付出去,如果再重新写一份文档难免有些麻烦.于是在网上看 ...
- linux or msys2设置网络代理
在文件 .bashrc 中添加 export http_proxy="proxy IP:port" 如 export http_proxy="192.168.0.1:80 ...