UVA11100旅行(大包装小包,问最少多少个包)
2014-12-07 14:22
246 查看
题意:
有n个包裹,每个包裹的大小都给出了,然后小的包裹可以装到大的包裹里,问最少装成多少个包裹,装成最小的包裹后还有一个限制就是让包裹数最多的那个包裹最少,就是说尽量都平均分,比如有6个,最少装成3个,平均就是全是2两个。
思路:
一开始没看到要求是平均分,按照出现次数sort一遍之后又用了一个map来插入序列,最后用一个O(n*log(n))的方法成功WA了一次,后来看到题目是平均分(哎!被白书上的题意坑好几回了),首先说明一点,就是最小的包数k就是最多出现的数字的次数,这个我想没必要在解释了吧,现在说一下平均分的问题,既然是平均分那么我们先把所有的数字从小到大拍一遍序,然后从第1个开始取,每次跳k步..然后从第2个开始每次跳k,最后每次拿出来的个数肯定是尽量平均的,还有很关键一点就是肯定不会拿出来相同的数字,因为每次+k,最多的数字出现的是k次,就算当前是最多的那个数字的第一个,那么+k只有也变成第k+1了,已经不是当前这个数字了,不明白的找个模拟很容易就懂了。
#include<stdio.h>
#include<algorithm>
#define N 10000 + 10
using namespace std;
int num
;
int main ()
{
int i ,max ,n;
while(~scanf("%d" ,&n) && n)
{
for(i = 1 ;i <= n ;i ++)
scanf("%d" ,&num[i]);
sort(num + 1 ,num + n + 1);
int now = 1;
for(max = 1 ,i = 2 ;i <= n ;i ++)
{
if(num[i] == num[i-1]) now ++;
else now = 1;
if(max < now) max = now;
}
printf("%d\n" ,max);
for(i = 1 ;i <= max ;i ++)
{
for(int j = i ;j <= n ;j += max)
if(j == i) printf("%d" ,num[j]);
else printf(" %d" ,num[j]);
puts("");
}
}
return 0;
}
有n个包裹,每个包裹的大小都给出了,然后小的包裹可以装到大的包裹里,问最少装成多少个包裹,装成最小的包裹后还有一个限制就是让包裹数最多的那个包裹最少,就是说尽量都平均分,比如有6个,最少装成3个,平均就是全是2两个。
思路:
一开始没看到要求是平均分,按照出现次数sort一遍之后又用了一个map来插入序列,最后用一个O(n*log(n))的方法成功WA了一次,后来看到题目是平均分(哎!被白书上的题意坑好几回了),首先说明一点,就是最小的包数k就是最多出现的数字的次数,这个我想没必要在解释了吧,现在说一下平均分的问题,既然是平均分那么我们先把所有的数字从小到大拍一遍序,然后从第1个开始取,每次跳k步..然后从第2个开始每次跳k,最后每次拿出来的个数肯定是尽量平均的,还有很关键一点就是肯定不会拿出来相同的数字,因为每次+k,最多的数字出现的是k次,就算当前是最多的那个数字的第一个,那么+k只有也变成第k+1了,已经不是当前这个数字了,不明白的找个模拟很容易就懂了。
#include<stdio.h>
#include<algorithm>
#define N 10000 + 10
using namespace std;
int num
;
int main ()
{
int i ,max ,n;
while(~scanf("%d" ,&n) && n)
{
for(i = 1 ;i <= n ;i ++)
scanf("%d" ,&num[i]);
sort(num + 1 ,num + n + 1);
int now = 1;
for(max = 1 ,i = 2 ;i <= n ;i ++)
{
if(num[i] == num[i-1]) now ++;
else now = 1;
if(max < now) max = now;
}
printf("%d\n" ,max);
for(i = 1 ;i <= max ;i ++)
{
for(int j = i ;j <= n ;j += max)
if(j == i) printf("%d" ,num[j]);
else printf(" %d" ,num[j]);
puts("");
}
}
return 0;
}
相关文章推荐
- 有一个糖果店的糖果有三种包装,分别是小包有6颗,中包有9颗,大包有20颗,如果我们只按整包买糖果,请问不能买到的糖果数最多是多少颗?
- uva 11584 题目大意: 给一个字符串, 要求把它分割成若干个子串,使得每个子串都是回文串。问最少可以分割成多少个。
- UVa 11100 旅行2007
- uva11100 - The Trip, 2007(旅行2007)
- UVA 11584 或 BNU20002 划分成回文串 DP求一个串最少能划分成多少个文回串
- UVA11100_旅行
- 旅行 The Trip, 2007 UVA - 11100 构造&输出技巧
- UVA11548 DP计算添加多少元素可以构成回文字符串
- 硬币找钱问题,求所有可能解决方案数目,最少的钱币数目,每种钱币用多少张
- UVALive 3621 Power Calculus n次幂最少需要几次乘除得到 搜索
- android TextView字体设置最少占多少行. 及其 Java String 字符串操作 . .
- uva 1347 Tour 旅行
- Risk UVA - 12264 拆点法+最大流+二分 最少流量的节点流量尽量多。
- UVA-11584 Partitioning by Palindromes 动态规划 回文串的最少个数
- hdoj 3836 Equivalent Sets【scc&&缩点】【求最少加多少条边使图强连通】
- 有1000桶酒,其中1桶有毒.而一旦吃了,毒性会在1周后发作.现在我们用小老鼠做实验,要在1周内找出那桶毒酒,问最少需要多少老鼠.
- Confusing Date Format UVALive 7711 给定mm-mm-mm格式的时间。年份(1900-1999)只给了后两位数,问有多少种合法的排列使时间正确。
- poj 1159 最少添加多少字符成回文串
- uva10056 - What is the Probability ?(概率是多少)
- 有1000桶酒,其中1桶有毒。请问最少需要多少只老鼠