1559: 外卖的撕‘哔’大战
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 695 Solved: 135
[ Submit][ Status][ Web Board]
Description
“订外卖就上XXX,满X减Y,满X减Y...”这样的声音老回荡在我们耳旁。发传单,拉条幅的宣传手段也屡见不鲜。外卖的撕‘哔’大战充满血雨腥风,不过作为消费者,我们的问题是:“已知N种类似满X减Y的优惠,请问你想点M次外卖,最少出多少钱呢?”。(P.S:各优惠不能叠加,外卖不能拼单拆单。)
Input
多组数据,第一行有一个整数T,表示有T组数据。(T<=100)
以下每组数据第一行有两个整数N和M,表示外卖网站的优惠种数和你想点的外卖个数。(1<=N,M<=100)
然后接下来N行,每行两个整数ai,bi,表示一种优惠为满ai元可减bi元。(ai>=bi)
最后一行是M个整数,表示你每次点的外卖的价格。
所有的数据不会超过int。
Output
每组数据输出一行,为一个整数,是你在所有外卖上的花销。
Sample Input
2
3 3
5 3
10 6
20 8
5 10 20
3 3
5 5
10 10
20 20
6 10 20
Sample Output
18
1
HINT
模拟题。
把题意搞明白了就行。
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
const int MAXN=105;
typedef struct
{
int all,cut;
}Node;
Node a[MAXN];
int nums[MAXN];
bool cmp(Node x,Node y)
{
if(x.cut==y.cut)
return x.all<y.all;
return x.cut>y.cut;
}
int main()
{
int t,m,n;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++)
scanf("%d%d",&a[i].all,&a[i].cut);
for(int i=0;i<m;i++)
scanf("%d",&nums[i]);
sort(a,a+n,cmp);
int cnt=0;
for(int i=m-1;i>=0;i--)
{
int temp=nums[i];
int index=-1;
for(int j=0;j<n;j++)
{
if(nums[i]>=a[j].all)
{
temp=nums[i]-a[j].cut;
break;
}
}
cnt+=temp;
}
printf("%d\n",cnt);
}
return 0;
}