4005:拼点游戏(贪心算法)
- 总时间限制:
- 1000ms
- 内存限制:
- 65536kB
- 描述
- C和S两位同学一起玩拼点游戏。有一堆白色卡牌和一堆蓝色卡牌,每张卡牌上写了一个整数点数。C随机抽取n张白色卡牌,S随机抽取n张蓝色卡牌,他们进行n回合拼点,每次两人各出一张卡牌,点数大者获得三颗巧克力,小者获得一颗巧克力,如果点数相同,每人各得二颗巧克力,使用过的卡牌不得重复使用。已知C和S取到的卡牌点数,请编程计算S最多和最少能得到多少颗巧克力。
- 输入
- 输入包含多组测试数据。
每组测试数据的第一行是一个整数n(1<=n<=1000),接下来一行是n个整数,表示C抽到的白色卡牌的点数,下一行也是n个整数,表示S抽到的蓝色卡牌的点数。
输入的最后以一个0表示结束。 - 输出
- 对每组数据,输出一行,内容是两个整数用空格格开,分别表示S最多和最少可获得的巧克力数。
- 样例输入
-
3 92 83 71 95 87 74 2 20 20 20 20 2 20 19 22 18 0
- 样例输出
-
9 5 4 4 4 4
1 #include <bits/stdc++.h> 2 using namespace std; 3 4 int n,c[1001],s[1001]; 5 6 int fun(int a[],int b[]) {//a能最多获得的糖豆数 7 int ans=0,al=0,ar=n-1,bl=0,br=n-1,num=0; 8 while(num<n){ 9 num++; 10 if(a[ar]>b[br]){ 11 ans+=3; 12 ar--; 13 br--; 14 } 15 else if(a[al]>b[bl]){ 16 ans+=3; 17 al++; 18 bl++; 19 } 20 else { 21 if(a[al]==b[br]){ 22 ans+=2; 23 } 24 else{ 25 ans+=1; 26 } 27 al++; 28 br--; 29 } 30 } 31 return ans; 32 } 33 34 int main() { 35 while(cin>>n&&n!=0) { 36 int ans1=0,ans2=0; 37 for(int i=0; i<n; i++) { 38 cin>>c[i]; 39 } 40 for(int i=0; i<n; i++) { 41 cin>>s[i]; 42 } 43 sort(c,c+n); 44 sort(s,s+n); 45 ans1=fun(s,c); 46 ans2=4*n-fun(c,s); 47 cout<<ans1<<" "<<ans2<<endl; 48 } 49 50 51 return 0; 52 }
越努力越幸运