箭無虛發
Time Limit: 1000 MS | Memory Limit: 65536 KB |
Total Submissions: 128 | Accepted: 21 |
Description
對於每發一次箭,YZ給他4種成績(優、良、中、差),JH有三種拉弓以及瞄準時間a ,b,c(a>=b>=c)分別能拿優,良,中等級,如果不拉弓不瞄(直接射),只能拿差(不能中靶)了。
現在JH想知道,在保證自己彈無虛發(不獲得差)的情況下,最多能拿多少個優。
如果JH不能做到彈無虛發,輸出Oh,my god!
Input
對於每組數據,第一行爲一個整數n,表示總共有n支箭。
(0<n<=1000)
之後n行,每行包含三個數字a,b,c,分別表示拿對應等級所需要花的時間。
(0<c<=b<=a<=1000)
之後一個數字t,表示JH有考覈總時間爲t
(0<=t<=1e6)
Output
Sample Input
1
3 2 1
1
2
3 2 1
3 2 1
4
2
3 2 1
3 2 1
1
Sample Output
1
Oh,my god!
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
struct J
{
int a, b, c;
}a[1002];
bool cmp(J a, J b)
{
return a.a - a.c < b.a - b.c;
}
int main(int argc, char const *argv[])
{
int T, n, t, s;
scanf("%d", &T);
while (T--)
{
s = 0;
scanf("%d", &n);
for (int i=0; i<n; i++) {
scanf("%d%d%d", &a[i].a, &a[i].b, &a[i].c);
s += a[i].c;
}
scanf("%d", &t); //如果全得“中”的時間(最小花費)>考覈時間,就不能做到箭無虛發
if (s > t) printf("Oh,my god!\n");
else {
sort(a, a+n, cmp);//排序用到技巧,(得優的時間-得中的時間)按升序排序
int cnt = 0;
for (int i=0; i<n; i++) {
if (s - a[i].c + a[i].a <= t) {
s = s - a[i].c + a[i].a;//加一個優並減去一箇中的時間,貪心策略
cnt++;
}
else break;
}
printf("%d\n", cnt);
}
}
return 0;
}