【Uva 242】Stamps and Envelope Size
【Link】:
【Description】
给你n个集合;
每个集合都包含一些不同面额的邮票;
(每种邮票都当做有无限张)
然后给你一封信上最多能贴的邮票张数S;
问你,哪一个集合的邮票;
能够贴出来从1开始的,最大的连续邮票面额
优先输出小的集合,集合大小一样的话,从大到小排序后,字典序小的优先输出;
【Solution】
每个邮票都是一个物品;
假设每个邮票都最多能拿S个;
做一个多重背包即可
这里
设f[i][j]表示前i个邮票,邮票的总面额为j的情况最少需要的邮票张数;
对每个集合都做一个这样的多重背包;
然后根据f[n][]获取每个集合能获得的最大连续面额就好了;
(根据f[n][j]是否小于等于s判断能不能获得这个面额)
最后输出,是按照场宽输出。不然会PE
【NumberOf WA】
2
【Reviw】
背包的变形。
背包可以做很多事情.嗯。。
【Code】
#include <bits/stdc++.h>
using namespace std;
const int NN = 10;
const int S = 10;
const int MAX_SIZE = 1000;
const int INF = 0x3f3f3f3f;
int s,N,num[S+5],f[NN+5][MAX_SIZE+5];
vector <int> v[NN+5];
int get_ans(int idx,int n){
memset(f,INF,sizeof f);
f[0][0] = 0;
for (int i = 0;i <= n-1;i++)
for (int j = 0;j <= MAX_SIZE;j++)
if (f[i][j]<INF){
for (int k = 0;k <= s;k++){
int temp = j + k*v[idx][i+1];
f[i+1][temp] = min(f[i+1][temp],f[i][j]+k);
}
}
for (int i = 0;i <= MAX_SIZE+1;i++)
if (f[n][i] > s) return i-1;
return 520;
}
int cmp(int idx1,int idx2){
for (int i = num[idx1];i >= 1;i--)
for (int j = num[idx2];j >= 1;j--)
if (v[idx1][i]!=v[idx2][j]){
if (v[idx1][i] < v[idx2][j])
return 1;
else
return 0;
}
return 1;
}
int main(){
//freopen("F:\\rush.txt","r",stdin);
for (int i = 1;i <= 10;i++)
v[i].resize(11);
while (~scanf("%d",&s) && s){
scanf("%d",&N);
int ma = 0,maxid = 1;
for (int i = 1;i <= N;i++){
scanf("%d",&num[i]);
for (int j = 1;j <= num[i];j++)
scanf("%d",&v[i][j]);
int temp1 = get_ans(i,num[i]);
if (temp1 > ma){
ma = temp1;
maxid = i;
}else if (temp1 == ma){
if (num[i] < num[maxid]){
maxid = i;
}else if (num[i] == num[maxid]){
if (cmp(i,maxid) == 1)
maxid = i;
}
}
}
printf("max coverage =%4d :",ma);
for (int j = 1;j <= num[maxid];j++)
printf("%3d",v[maxid][j]);
puts("");
}
return 0;
}
【Uva 242】Stamps and Envelope Size的更多相关文章
- 【UOJ#242】【UR#16】破坏蛋糕(计算几何)
[UOJ#242][UR#16]破坏蛋糕(计算几何) 题面 UOJ 题解 为了方便,我们假定最后一条直线是从上往下穿过来的,比如说把它当成坐标系的\(y\)轴. 于是我们可以处理出所有交点,然后把它们 ...
- 【UVA 437】The Tower of Babylon(记忆化搜索写法)
[题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵
偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...
- 【贪心+中位数】【UVa 11300】 分金币
(解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...
- 【UVa 10881】Piotr's Ants
Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...
- 【UVa 116】Unidirectional TSP
[Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【UVa 1347】Tour
[Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【uva 1025】A Spy in the Metro
[题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【Uva 1630】Folding
[Link]: [Description] 你能对字符串进行压缩的操作; 即把连续出现的相同的子串改成它出现的次数+这个最基本的字符串的形式; 问你这个字符串最短能被压缩得多短; [Solution] ...
随机推荐
- JAVA:从public static void main(String args[])開始
我们都知道当你要执行一个JAVA文件的时候必需要有一个main函数. 这是为什么呢? 跟C语言的道理一样,当你执行一个文件的时候.你必需要有一个入口函数或者入口地址,在C里面是main函数.相同的在J ...
- MySql基础总结(1)
对于MySql已经是第二次看了,这次基本的目的是将MySql系统的归纳一边,之前学MySql是将笔记写在本子上,以后不想总带着本子,所以再花点时间把笔记归纳在博客中. 下午已将安装步骤具体的写了.如今 ...
- leetcode——Insertion Sort List 对链表进行插入排序(AC)
Sort a linked list using insertion sort. class Solution { public: ListNode *insertionSortList(ListNo ...
- redis作为缓存场景使用,内存耗尽时,突然出现大量的逐出,在这个逐出的过程中阻塞正常的读写请求,导致 redis 短时间不可用
redis 突然大量逐出导致读写请求block 内容目录: 现象 背景 原因 解决方案 ref 现象 redis作为缓存场景使用,内存耗尽时,突然出现大量的逐出,在这个逐出的过程中阻塞正常的读写请 ...
- [USACO09JAN] 气象测量/气象牛The Baric Bovine 解题报告(DP)
题目链接:https://www.luogu.org/problemnew/show/P2933 Description 为了研究农场的气候,Betsy帮助农夫John做了N(1 <= N &l ...
- java操作文件创建、删除
java操作文件创建.删除: package test; import java.io.File; import java.io.IOException; import org.slf4j.Logge ...
- sql索引碎片产生的原理 解决碎片的办法(sql碎片整理)
本文讲述了SQL SERVER中碎片产生的原理,内部碎片和外部碎片的概念.以及解决碎片的办法和填充因子.在数据库中,往往每一个对于某一方面性能增加的功能也会伴随着另一方面性能的减弱.系统的学习数据库知 ...
- codeforces 404 B Marathon【fmod对浮点数取余】
题意:给出一个边长为a的正方形,给出d,给出n,输出走得距离为i个d的时候的坐标 学习的这一篇 http://blog.csdn.net/synapse7/article/details/215956 ...
- caffe(6) Blob,Layer,Net 以及对应配置文件的编写
深度网络(net)是一个组合模型,它由许多相互连接的层(layers)组合而成.Caffe就是组建深度网络的这样一种工具,它按照一定的策略,一层一层的搭建出自己的模型.它将所有的信息数据定义为blob ...
- PHP实现杨辉三角形
<?php /**** * 杨辉三角形:我的实现方式. * 下标 * 1 0 * 1 1 1 循环上一行数据1次,计算后结果追加到当前行末尾 * 1 2 1 2 * 1 3 3 1 3 * 1 ...