【Uva 10163】Storage Keepers
【Link】:
【Description】
你有n(n≤100)个相同的仓库。有m(m≤30)个人应聘守卫,第i个应聘者的能力值 为Pi(1≤Pi≤1000)。每个仓库只能有一个守卫,但一个守卫可以看守多个仓库。如果应聘 者i看守k个仓库,则每个仓库的安全系数为Pi/K的整数部分。没人看守的仓库安全系数为0。
你的任务是招聘一些守卫,使得所有仓库的最小安全系数最大,在此前提下守卫的能力 值总和(这个值等于你所需支付的工资总和)应最小。
【Solution】
动规
能力总和最大值为30000
安全系数[0..1000]
100个仓库,30个应聘人
设f[i][k][j]表示
前i个应聘人,安排好了k个仓库,最小安全系数为j的最小能力总和
枚举第i个人选择了多少个仓库;
做一下状态转移就好;
(顺推比较好写吧)
如果没有安排满n个仓库,直接输出”0 0”就好
【NumberOf WA】
0
【Reviw】
找题目中的一些参数,尝试用那些参数作为动态规划的状态;
【Code】
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int M = 30;
const int K = 100;
const int S = 1000;
const int INF = 0x3f3f3f3f;
int f[M+5][K+5][S+5],p[M+5],n,m;
main(){
//freopen("F:\\rush.txt","r",stdin);
while (~scanf("%lld%lld",&n,&m)){
if (n==0 && m==0) break;
for (int i = 1;i <= m;i++)
scanf("%lld",&p[i]);
memset(f,INF,sizeof f);
f[0][0][1001] = 0;
for (int i = 0;i <= m-1;i++)
for (int j = 0;j <= n;j++)//枚举已经安排好的仓库个数
for (int k = 0;k <= 1001;k++) //枚举最小安全值
if (f[i][j][k] < INF){
for (int tj = 0;tj <= n-j;tj++){//枚举第i+1个人要守卫几个
//i+1 j+tj min(k,p[i+1]/tj)
if (tj==0){
f[i+1][j][k] = min(f[i+1][j][k],f[i][j][k]);
}else{
f[i+1][j+tj][min(k,p[i+1]/tj)] = min(
f[i+1][j+tj][min(k,p[i+1]/tj)],f[i][j][k]+p[i+1]);
}
}
}
int ans = INF,pos = 1001;
for (int i = 1000;i >= 1;i--)
if (f[m][n][i]<INF){
ans = f[m][n][i];
pos = i;
break;
}
if (ans<INF){
printf("%lld %lld\n",pos,ans);
}else{
puts("0 0");
}
}
return 0;
}
【Uva 10163】Storage Keepers的更多相关文章
- 【巧妙算法系列】【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 437】The Tower of Babylon(记忆化搜索写法)
[题目链接]: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 11584】Partitioning by Palindromes
[Link]:https://cn.vjudge.net/contest/170078#problem/G [Description] 给你若干个只由小写字母组成的字符串; 问你,这个字符串,最少能由 ...
- 【Uva 11400】Lighting System Design
[Link]: [Description] 你要构建一个供电系统; 给你n种灯泡来构建这么一个系统; 每种灯泡有4个参数 1.灯泡的工作电压 2.灯泡的所需的电源的花费(只要买一个电源就能供这种灯泡的 ...
随机推荐
- Ubuntu下哪个PDF阅读器更好使???
根据windows系统上的经验,果断选择了foxit reader的linux版本: 从 http://www.foxitsoftware.com/downloads/ 选择 “Desktop Lin ...
- Python学习七步走
在周五的下午三点钟(为什么是这个时间?因为事情总会在周五下午三点钟发生),你收到一条通知,客户发现你的软件出现一个错误.在有了初步的怀疑后,你联系运维,查看你的软件日志以了解发生了什么,因为你记得收到 ...
- [HAOI2006]旅行(并查集)
寒假填坑五十道省选题——第五道 [HAOI2006]旅行 题目描述 Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N个景点(编号为1,2,3,…,N),这些景点被M条道路 ...
- [转] C# HttpWebRequest 绝技
c# HttpWebRequest与HttpWebResponse绝技 阅读原文 如果你想做一些,抓取,或者是自动获取的功能,那么就跟我一起来学习一下Http请求吧.本文章会对Http请求时的G ...
- Android Studio获取开发版SHA1值和发布版SHA1值,详细过程
转自原文 Android Studio获取开发版SHA1值和发布版SHA1值的史上最详细方法 前言: 今天我想把百度地图的定位集成到项目中来,想写个小小的案例,实现一下,但在集成百度地图时首先要申请秘 ...
- static_cast 与 dynamic_cast
- 第6章8节《MonkeyRunner源代码剖析》Monkey原理分析-事件源-事件源概览-小结
本章我们重点环绕处理网络过来的命令的MonkeySourceNetwork这个事件源来阐述学习Monkey是怎样处理MonkeyRunner过来的命令的.以下总结下MonkeyRunner从启动Mon ...
- Visual Studio2008 和2010 执行程序出现的黑框马上消失解决方法
1 在程序最后加 system("PAUSE"); 要注意包括头文件#include"stdlib.h" //system须要调用这个 ...
- vim使用(二):经常使用功能
1. vim经常使用功能 vim的经常使用功能.包含块的选择.复制,多文件的编辑.多窗体等功能. 2. vim块选择 块选择是将文档中的一块能够选择复制,粘贴,不用整行的处理. 按下 v , V . ...
- 128.C++文件操作小结
打开后缀参数 #include <fstream> #include <iostream> using namespace std; //文本读写 //文件写入 void ma ...