POJ 2497 Strategies
题意:有三个人,Bill, Steve and Linus,他们参加竞赛,给出竞赛的题目和比赛时间,然后给出每道题需要的时间(他们解同一道题花的时间相同),然后他们有不同的策略来做题。每道题的得分为当前比赛进行的时间,最后的得分为所有题目得分的和。最后做出题目最多的人获胜(若做出题目数目相同,则看得分最少)。如果三人都相同,那么规定Steve为胜者。(我在想一个问题,会不会出现这种情况,那就是Bill和Linus做的题目相同,且他俩排名高于Steve,那么胜者应该是Bill还是Linus???------貌似应该不会出现这种情形)
3人得策略如下,
Bill: 按题目给的顺序依次往下做
Steve: 先做花费时间小的题目
Linus:先做花费时间大的题目
思路:直接的想法就是,直接把三个人结果的求出来,比较一下,得出胜者(我也是这么做的)
但是,看了poj讨论版中的评论,有的说这样的策略很明显胜者就是Steve,因为他这是最优的策略。自己想想也是这么回事。。。那么直接求Steve的结果,输出就ok了
代码:分别求的三个人得结果,进行比较
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; struct node{
int p;//解题数目
int s;//得分
int y;//优先级,把Steve的设为最高,在最后排序时使用
char name[10];//姓名
};
bool cmp(node a,node b){
if(a.p!=b.p) return a.p>b.p;//解题数目多的在前
if(a.s!=b.s) return a.s<b.s;//得分少的在前
return a.y<b.y;//当解题数目和得分相同时,把Steve排在最前面
}
int main(){
int n,n2,totaltime,num,a[30],i,timeused,testcase=0;
node p[3];
scanf("%d",&n);//测试组数
n2=n;
while(n2--){
testcase++;
timeused=0;
scanf("%d%d",&totaltime,&num);//比赛时间,题目数量
memset(p,0,sizeof(p));
p[0].y=p[2].y=1;
strcpy(p[0].name,"Bill");
strcpy(p[1].name,"Steve");
strcpy(p[2].name,"Linus");
for(i=0;i<num;i++)//输入每道题所花费的时间
scanf("%d",&a[i]);
for(i=0;i<num;i++){//Bill得分
timeused=timeused+a[i];
if(timeused>totaltime) break;
p[0].p++;
p[0].s=p[0].s+timeused;
}
sort(a,a+num);//把题目按时间升序
timeused=0;
for(i=0;i<num;i++){//Steve得分
timeused=timeused+a[i];
if(timeused>totaltime) break;
p[1].p++;
p[1].s=p[1].s+timeused;
}
timeused=0;
for(i=num-1;i>=0;i--){//Linus得分
timeused=timeused+a[i];
if(timeused>totaltime) break;
p[2].p++;
p[2].s=p[2].s+timeused;
}
sort(p,p+3,cmp);//排序,排完后第一名在p[0]
printf("Scenario #%d:\n",testcase);
printf("%s wins with %d solved problems and a score of %d.\n",p[0].name,p[0].p,p[0].s);
if(testcase<n) printf("\n");
}
return 0;
}
POJ 2497 Strategies的更多相关文章
- POJ 3370. Halloween treats 抽屉原理 / 鸽巢原理
		Halloween treats Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 7644 Accepted: 2798 ... 
- POJ 2356. Find a multiple 抽屉原理 / 鸽巢原理
		Find a multiple Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7192 Accepted: 3138 ... 
- POJ 2965. The Pilots Brothers' refrigerator 枚举or爆搜or分治
		The Pilots Brothers' refrigerator Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 22286 ... 
- POJ 1753. Flip Game 枚举or爆搜+位压缩,或者高斯消元法
		Flip Game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 37427 Accepted: 16288 Descr ... 
- POJ 3254. Corn Fields 状态压缩DP (入门级)
		Corn Fields Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 9806 Accepted: 5185 Descr ... 
- POJ 2739. Sum of Consecutive Prime Numbers
		Sum of Consecutive Prime Numbers Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 20050 ... 
- POJ 2255. Tree Recovery
		Tree Recovery Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 11939 Accepted: 7493 De ... 
- POJ 2752 Seek the Name, Seek the Fame [kmp]
		Seek the Name, Seek the Fame Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 17898 Ac ... 
- poj 2352 Stars 数星星 详解
		题目: poj 2352 Stars 数星星 题意:已知n个星星的坐标.每个星星都有一个等级,数值等于坐标系内纵坐标和横坐标皆不大于它的星星的个数.星星的坐标按照纵坐标从小到大的顺序给出,纵坐标相同时 ... 
随机推荐
- 常见函数strlen、strcmp、strstr原型实现
			数组元素的结束符为'\0'.串的结束符为NULL 一.strlen #include <iostream> using namespace std; long h_strlen(const ... 
- 进程间通信(IPC)介绍(转)
			进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息. IPC的方式通常有管道(包括无名管道和命名管道).消息队列.信号量.共享存储.Socket ... 
- winform制作自定义控件
			一 .概述Windows 窗体控件是可再次使用的组件,它们封装了用户界面功能,并且可以用于客户端 Windows 应用程序.“Windows 窗体”不仅提供了许多现成控件,还提供了自行开发控件的基础结 ... 
- cheap louis vuitton outlet
			<h1>louis vuitton outlet store</h1>2 nigerian networking systems chosen seeing that enem ... 
- python解释器分类
			当我们编写Python代码时,我们得到的是一个包含Python代码的以.py为扩展名的文本文件.要运行代码,就需要Python解释器去执行.py文件. 由于整个Python语言从规范到解释器都是开源的 ... 
- Codeforces 223C Partial Sums  数论+组合数学
			题意非常easy,求不是那么好求的,k非常大 要操作非常多次,所以不可能直接来的.印象中解决操作比較多无非线段树 循环节 矩阵 组合数等等吧,这道题目 也就仅仅能多画画什么 的了 就以第一个案例为主吧 ... 
- Android Camera API2中采用CameraMetadata用于从APP到HAL的参数交互
			前沿: 在全新的Camera API2架构下,常常会有人疑问再也看不到熟悉的SetParameter/Paramters等相关的身影,取而代之的是一种全新的CameraMetadata结构的出现,他不 ... 
- php   selenium 测试验证码问题
			$this->pause(10000)这段代码用于停止程序执行,可以在这个空隙内输入验证码 
- XMPP资源绑定(Resource Binding)
			一个XMPP的账号由三部分组成: 用户名(user/node),域名(domain)和资源(resource) .例如 alice@xmpp.irusher.com/mobile ,user部分(或n ... 
- sed命令使用举例
			选择操作的行范围 sed -n '1,2p' testsed2.txt 匹配第1到2行 sed -n '/a/,/b/p' testsed2.txt 匹配从包含a的行到包含b的行 sed -n ' ... 
