sdut2408 pick apples (贪心+背包)山东省第三届ACM省赛
版权声明:本文为博主原创文章。未经博主同意不得转载。
https://blog.csdn.net/svitter/article/details/24642587
本文出自:http://blog.csdn.net/svitter/
题意:三种苹果,每种都有相应的Size,Value,给你一个背包空间,求最大的价值。
本题目的关键就在于很大的背包空间
根据indicates the size (1 <= S<=
100) 我们能够考虑在1000000(100^3)之外的空间放性价比最高的苹果。
为什么时100^3?
要知道背包假设正好填满,而填满空间相应价值的苹果大于不填满的价值的苹果,那么就选择能填满空间而使价值最大的苹果,而非性价比最高的苹果——性价比高的苹果可能由于剩下的空间不足,而造成空间利用不充分达不到最大价值。100^3大于不论什么3个苹果的Size的最大公倍数,所以选择100^3这个数字。
另:之前把f[1000001]初值赋值为-1, 以此来求背包- =太水了= =全然没有考虑到最后一个f[BagSize]可能为-1的情况。然后写了一个找不是-1的最大Bag值,又水了- =当赋值-1的时候。未必最大的就是空间用的最多的。
简单举例:
BagSize 60, a[1] 59/30, a[2].size 58/31 a[3].size 57/32;
贴代码:
#include <iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
#define lln long long int
struct Apple
{
int Value;
int Size;
double Cost;
};
Apple a[3];
lln f[1001000];
void ace()
{
int t, i, j, no, most;
int BagSize, tempBag;
double cost;
lln RestNum, ans, RestValue;
int Size;
scanf("%d", &t);
for(no = 1; no <= t; no++)
{
memset(f, 0, sizeof(f));
f[0] = 0;
most = 0; cost = 0;
for(i = 0; i < 3; i++)
{
scanf("%d %d", &a[i].Size, &a[i].Value);
a[i].Cost = ((double) a[i].Value) / a[i].Size;
if(a[i].Cost > cost)//find the most
{
most = i;
cost = a[i].Cost;
}
}
scanf("%d", &BagSize);
RestNum = 0;
RestValue = 0;
//大于1000的时候,把性价比最高的苹果填入
if(BagSize > 1000000)
{
tempBag = BagSize - 1000000;
RestNum = tempBag / a[most].Size;
BagSize -= RestNum * a[most].Size;
RestValue = RestNum * a[most].Value;
}
//剩余的苹果使用背包
for(i = 0; i < 3; i++)
{
Size = BagSize - a[i].Size;
for(j = 0; j <= Size; j++)
{
f[j + a[i].Size] = max(f[j + a[i].Size], f[j] + a[i].Value);
}
}
ans = RestValue + f[BagSize];
printf("Case %d: %lld\n", no, ans);
}
}
int main()
{
ace();
return 0;
}
sdut2408 pick apples (贪心+背包)山东省第三届ACM省赛的更多相关文章
- 山东省第三届ACM省赛
Solved ID PID Title Accepted Submit A 2407 Impasse (+) 0 0 B 2415 Chess 0 0 C 2414 An interest ...
- Sdut 2409 The Best Seat in ACM Contest(山东省第三届ACM省赛 H 题)(模拟)
题目描述 Cainiao is a university student who loves ACM contest very much. It is a festival for him once ...
- Sdut 2416 Fruit Ninja II(山东省第三届ACM省赛 J 题)(解析几何)
Time Limit: 5000MS Memory limit: 65536K 题目描述 Haveyou ever played a popular game named "Fruit Ni ...
- [原]sdut2624 Contest Print Server (大水+大坑)山东省第四届ACM省赛
本文出自:http://blog.csdn.net/svitter 原题:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&am ...
- [2012山东省第三届ACM大学生程序设计竞赛]——n a^o7 !
n a^o7 ! 题目:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2413 Time Lim ...
- [2012山东省第三届ACM大学生程序设计竞赛]——Mine Number
Mine Number 题目:http://acm.sdut.edu.cn/sdutoj/problem.php? action=showproblem&problemid=2410 Time ...
- 2012年"浪潮杯"山东省第三届ACM大学生程序设计竞赛--n a^o7 ! 分类: 比赛 2015-06-09 17:16 14人阅读 评论(0) 收藏
n a^o7 ! Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 All brave and intelligent fighte ...
- 山东省第八届ACM省赛游记
Day 1: 凌晨,来了几分兴致,和队友在VJudge上开了一把zoj月赛,WA一发闷一口拿铁,一瓶拿铁 不一会就被喝完了!好气啊!遂开始愉快地打游戏,打着打着,woc,居然3点半了,小睡片 刻,咬上 ...
- 山东省第五届ACM省赛
题目链接:http://acm.sdut.edu.cn/sdutoj/contest_show.php?contest_id=1449 相关总结:http://www.cnblogs.com/mcfl ...
随机推荐
- android--------面试题收集
Android是一种基于Linux的自由及开放源代码的操作系统,主要使用于移动设备,如智能手机和平板电脑,由Google公司和开放手机联盟领导及开发.这里会不断收集和更新Android基础相关的面试题 ...
- android--------验证码倒计时
在我们注册或者修改信息的时候,常会用到60s倒计时这个功能,写了这篇文章,大家共享一下: 效果图: 直接上代码: activity.java public class MainActivity ext ...
- Jon Snow and his Favourite Number CodeForces - 768C (技巧)
链接 题意 给定数组, 每次操作先将数组排序, 再将奇数位全部异或x, 求k次操作后数组最大值与最小值 (1 ≤ n ≤ 105, 0 ≤ k ≤ 105, 0 ≤ x ≤ 103) 题解 直接暴力模 ...
- ECharts学习(1)--toolbox(工具栏)
1. toolbox:这是ECharts中的工具栏.内置有导出图片.数据视图.动态类型切换.数据区域缩放.重置五个工具. 2. toolbox中的属性,不包含五个工具.里面最主要的就是feature这 ...
- UVA-1252 Twenty Questions (状压DP)
题目大意:有n件物品,每件物品有m个特征,可以对特征进行询问,询问的结果是得知某个物体是否含有该特征,要把所有的物品区分出来(n个物品的特征都互不相同)最小需要多少次询问? 题目分析:定义dp(s,a ...
- Leetcode 22
//这题感觉不如前两题回溯清楚,还要再看看class Solution { public: vector<string> generateParenthesis(int n) { vect ...
- HDOJ1000
#include<iostream> using namespace std; int main() { int a,b; while(cin >> a >> b) ...
- Delegate比较全面的例子(需整理)
将Delegate理解为接口,只有一个方法的接口,这样最容易理解.这个方法只有声明,没有实现,实现在别的类.(实际上应该把它看作函数指针,不过接口更容易理解些.) 在你的类中有一个Delegate就相 ...
- 根据服务端生成的WSDL文件创建客户端支持代码的三种方式
第一种:使用wsimport是JDK自带的工具,来生成 生成java客户端代码常使用的命令参数说明: 参数 说明 -p 定义客户端生成类的包名称 -s 指定客户端执行类的源文件存放目录 -d 指定客户 ...
- spring boot 学习(十二)拦截器实现IP黑名单
拦截器实现IP黑名单 前言 最近一直在搞 Hexo+GithubPage 搭建个人博客,所以没怎么进行 SpringBoot 的学习.所以今天就将上次的”?秒防刷新”进行了一番修改.上次是采用注解加拦 ...