hdu2844 & poj1742 Coin ---多重背包--两种方法
意甲冠军:你有N种硬币,每个价格值A[i],每个号码C[i],要求。
在不超过M如果是,我们用这些硬币,有多少种付款的情况下,。那是,:1,2,3,4,5,....,M这么多的情况下,,你可以用你的硬币不找零,种情况。
比如:
你有一种硬币,价值2。个数2,那么 你是不能付款 3元的。。你仅仅能付款2,或者4元。。
OK,题意差点儿相同就是这样啦。
那么这里有两种方式!
分析:
那么这里我们能够用多重背包来解决,我们把价值和重量看成一样的w[i] = A[i];用M作为背包。
那么dp 过后。我们就能够知道 dp[i] 表示的含义为,不超过i元钱的情况下,用拥有的硬币能构成的最大钱数。那么非常明显,假设dp[i] = i,意思就是 用拥有的钱,能够刚好构成 i 元钱,上马:
//281MS 648K
#include <stdio.h>
#include <string.h> #define MAX 102 int ans;//最后答案
int n,m;
int A[MAX],C[MAX];
int dp[100005]; void ZeroOne(int V,int W)
{
for(int i = m; i >= V; i--)
//dp[i] = dp[i]>dp[i-V]+W ? dp[i]:dp[i-V]+W;
if(dp[i]<dp[i-V]+W)
{
dp[i] = dp[i-V]+W;//这里需改动如此统计
if(dp[i] == i) ans ++;//在dp过程中,会有出现dp[j]更新为j的时候 且仅仅有一次,也要放在dp[i]=dp[i-V]+W;此语句后
}
} int main()
{
while(scanf("%d%d",&n,&m),n+m)
{
ans = 0;
memset(dp,0,sizeof(dp));
for(int i = 1; i <= n; i ++) scanf("%d",&A[i]);
for(int i = 1; i <= n; i ++) scanf("%d",&C[i]); for(int i = 1; i <= n; i ++)
{
if(A[i]*C[i] >= m)
{
for(int j = A[i]; j <= m; j ++)
//dp[j] = dp[j]>dp[j-A[i]]+A[i] ? dp[j]:dp[j-A[i]]+A[i]; //将价值和重量看做同样
if(dp[j]<dp[j-A[i]]+A[i]) //这里需改动如此统计ans
{
dp[j] = dp[j-A[i]]+A[i];
if(dp[j] == j) ans ++; //在dp过程中,会有出现dp[j]更新为j的时候 且仅仅有一次,也要放在dp[i]=dp[i-V]+W;此语句后
}
}
else
{
int k = 1;
while(k <= C[i])
{
ZeroOne(A[i]*k,A[i]*k);
C[i] -= k;
k *= 2;
}
ZeroOne(C[i]*A[i],C[i]*A[i]);
}
}
//for(int i = 1; i <= m; i ++) if(dp[i]==i)ans++;//这里用以用在hdu,可是poj须要用上面的方式统计ans,不然会超时,过了也过得非常险 2654ms........汗。。 。。 。 printf("%d\n",ans);
}
return 0;
}
那么这里另一种方式
用flag[i]表示能不能构成 钱为 i 的情况
time[j] 表示,构成 j 元钱的时候,用第 i 种硬币的个数
#include <iostream>
#include <cstring>
using namespace std; #define MAX 100005 int N,M;
int A[MAX],C[MAX];
bool flag[MAX];
int time[MAX]; int main()
{
while(cin >> N >> M)
{
if(!N && !M)break;
for(int i = 0; i < N; i ++) cin >> A[i];
for(int i = 0; i < N; i ++) cin >> C[i]; int ans = 0;
memset(flag,false,sizeof(flag));
flag[0] = true;
for(int i = 0; i < N; i ++){
memset(time,0,sizeof(time));
for(int j = A[i]; j <= M; j ++){//这里解释为。仅仅有当前j这样的情况没有构成,而且j-A[i]的情况存在--(这里也就是相似全然背包,这次状态应该依赖前面存在情况),同一时候到j为止。用第i种硬币的数量不超过C[i]的情况下才满足条件
if(!flag[j] && flag[j-A[i]] && time[j-A[i]]+1 <= C[i]){
flag[j] = true;
time[j] = time[j-A[i]]+1;
ans ++;
}
}
}
cout << ans <<endl;
}
return 0;
}
个人愚昧观点,欢迎指正与讨论
版权声明:本文博主原创文章,博客,未经同意不得转载。
hdu2844 & poj1742 Coin ---多重背包--两种方法的更多相关文章
- windows下获取IP地址的两种方法
windows下获取IP地址的两种方法: 一种可以获取IPv4和IPv6,但是需要WSAStartup: 一种只能取到IPv4,但是不需要WSAStartup: 如下: 方法一:(可以获取IPv4和I ...
- android 之 启动画面的两种方法
现在,当我们打开任意的一个app时,其中的大部分都会显示一个启动界面,展示本公司的logo和当前的版本,有的则直接把广告放到了上面.启动画面的可以分为两种设置方式:一种是两个Activity实现,和一 ...
- [转载]C#读写txt文件的两种方法介绍
C#读写txt文件的两种方法介绍 by 大龙哥 1.添加命名空间 System.IO; System.Text; 2.文件的读取 (1).使用FileStream类进行文件的读取,并将它转换成char ...
- php如何防止图片盗用/盗链的两种方法(转)
图片防盗链有什么用? 防止其它网站盗用你的图片,浪费你宝贵的流量.本文章向大家介绍php防止图片盗用/盗链的两种方法 Apache图片重定向方法 设置images目录不充许http访问 Apache服 ...
- WPF程序将DLL嵌入到EXE的两种方法
WPF程序将DLL嵌入到EXE的两种方法 这一篇可以看作是<Visual Studio 版本转换工具WPF版开源了>的续,关于<Visual Studio 版本转换工具WPF版开源了 ...
- MongoDB实现分页(两种方法)
1.插入实验数据 偷懒用下samus,100条. ; i < ; i++) { Document doc = new Document(); doc["ID"] = i; d ...
- css:图标与文字对齐的两种方法
(好久没写博客了,这几个月的积累比较零碎,记在本子上,现在开始整理归类) 在平时写页面的过程中,常遇到要把小图标与文字对齐的情况.比如: 总结了两种方法,代码量都比较少. 第一种 对img设置竖直方向 ...
- .net中创建xml文件的两种方法
.net中创建xml文件的两种方法 方法1:根据xml结构一步一步构建xml文档,保存文件(动态方式) 方法2:直接加载xml结构,保存文件(固定方式) 方法1:动态创建xml文档 根据传递的值,构建 ...
- 两种方法设置disabled属性
//两种方法设置disabled属性 $('#fileup').attr("disabled",true); $('#fileup').attr("disabled&qu ...
随机推荐
- 将jar要么aar公布到到网mvn 在(使用github作为仓库), 通过gradle dependency 信息集成
使用Android Studio用户开发,都希望通过maven该方式整合远程仓库jar.aar文件.但如何将这些文件发布它? 发人员都会将jar文件公布到sonatype上,以提供给其它开发人员集成, ...
- Socket规划(1)
socket定义 于Linux网络编程是通过socket进行的. 人们常说的socket是一种特殊的I/O接口,他也是一个文件描写叙述符.socket是一种经常使用的进程之间通信机制,通过它不仅能实现 ...
- APK ubuntu下 数字签名
Android系统要求每个Android应用程序必需要经过数字签名才可以安装到系统中,也就是说假设一个Android应用程序没有经过数字签名,是没有办法安装到系统中的! Android通过数字签名来标 ...
- gif动图快速制作方法(附工具)(转)
现在写博客或是wiki的过程中,会经常引用到图片,特别是客户端经常与页面相关所以截图不可避.但是越来越多的效果仅仅一张图片是无法清楚的描述.并且博客或是wiki也是支持gif图的.gif图的制作方法有 ...
- 【Unity技能】做一个简单的NPC
1. 写在前面 前几天我看到cgcookie一个教程.学习了下怎么依据已有人物模型制作一个仿版的NPC人物.感觉挺好玩的,整理一下放到博客里! 先看一下教程里面的终于效果. 是不是非常像个幽灵~ 以下 ...
- 【Spring】Spring学习笔记-01-入门级实例
听说当前Spring框架很流行,我也准备好好学学Spring开发,并将学习的过程和大家分享,希望能对志同道合的同学有所帮助. 以下是我学习Spring的第一个样例. 1.Spring开发环境的搭建 我 ...
- 让Emeditor支持markdown编辑博客
让Emeditor支持markdown编辑博客 1. 关于高亮显示 2.生成HTML文件并预览 用惯了Emeditor,最近又开始学习用markdown写博客,怎么让Emeditor支持markdow ...
- JS于string 和 json互转对象
一.json开启string JSON.stringify(jsonObj) 两.string开启json eval(string) 版权声明:本文博主原创文章.博客,未经同意不得转载.
- RH033读书笔记(13)-Lab 14 Network Clients
Goal: Practice using a variety of tools to transfer files between your system and a remote system. S ...
- Android使用开源项目Xutils实现多线程下载文件
#1.下载utils项目 https://github.com/wyouflf/xUtils #2布局文件里实现UI <LinearLayout xmlns:android="http ...