【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的更多相关文章

  1. 【UOJ#242】【UR#16】破坏蛋糕(计算几何)

    [UOJ#242][UR#16]破坏蛋糕(计算几何) 题面 UOJ 题解 为了方便,我们假定最后一条直线是从上往下穿过来的,比如说把它当成坐标系的\(y\)轴. 于是我们可以处理出所有交点,然后把它们 ...

  2. 【UVA 437】The Tower of Babylon(记忆化搜索写法)

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  3. 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵

    偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...

  4. 【贪心+中位数】【UVa 11300】 分金币

    (解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...

  5. 【UVa 10881】Piotr's Ants

    Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...

  6. 【UVa 116】Unidirectional TSP

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  7. 【UVa 1347】Tour

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  8. 【uva 1025】A Spy in the Metro

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  9. 【Uva 1630】Folding

    [Link]: [Description] 你能对字符串进行压缩的操作; 即把连续出现的相同的子串改成它出现的次数+这个最基本的字符串的形式; 问你这个字符串最短能被压缩得多短; [Solution] ...

随机推荐

  1. reverse(两种反向生成url django原生形式和rest_framework中版本的形式)

    reverse(两种反向生成url django原生形式和rest_framework中版本的形式) views.py from django.shortcuts import render,Http ...

  2. 将ubuntu安装在用剩下的硬盘改装成的移动硬盘时遇到的问题及解决办法

    安装时分完盘后提示:“分配到/的分区开始于3584字节,使用磁盘的最小对齐,这可能造成非常差的性能..." 解决办法: 回到windows使用分区助手等工具先分好盘而不是在安装时分盘(这样分 ...

  3. POJ 4007 Flood-it!

    题目:http://poj.org/problem?id=4007 思路: (lyd学长的思路) IDA*算法,首先迭代加深限制搜索深度. 可以发现如果当前矩阵中除了左上角的连通块之外,共有M种颜色, ...

  4. 模拟select样式,自定义下拉列表为树结构

    效果图如下: 首先,需要用到的库jQuery,zTree(官网API:http://www.treejs.cn/v3/api.php) 注意:因为zTree是基于jQuery的,所以应该先引入jQue ...

  5. array.fliter无法正确过滤出我想要的数组

    var checked_list = state.files.filter(function(item, id){ // console.log('click the ' + item.id); re ...

  6. sql的系统关键字的概述

    create proc proc_B as SELECT * FROM [ZkbTest].[dbo].[T_ZKB] exec sp_helptext proc_B select * from sy ...

  7. 【转载】AngularJS 用$sce服务来过滤HTML标签,解决无法正确显示后台传递的html标签

    angular js的强大之处之一就是他的数据双向绑定这一牛B功能,我们会常常用到的两个东西就是ng-bind和针对form的ng-model.但在我们的项目当中会遇到这样的情况,后台返回的数据中带有 ...

  8. caffe(12) 训练自己的数据

    学习caffe的目的,不是简单的做几个练习,最终还是要用到自己的实际项目或科研中.因此,本文介绍一下,从自己的原始图片到lmdb数据,再到训练和测试模型的整个流程. 一.准备数据 有条件的同学,可以去 ...

  9. bzoj1457: 棋盘游戏 SG函数 Nim

    Code: #include<cstdio> #include<cstring> using namespace std; #define maxn 1003 #define ...

  10. mysql 导出到 mongodb 与快速插入测试数据

    快速插入数据: 因为 MongoDB 的底层引擎是 JS 引擎,所以完全可以使用一些 Js 的语法.   for(var i=0;i<10000;i++){    db.ceshi.insert ...