Problem Description
Here is a famous story in Chinese
history.



"That was about 2300 years ago. General Tian Ji was a high official
in the country Qi. He likes to play horse racing with the king and
others."



"Both of Tian and the king have three horses in different classes,
namely, regular, plus, and super. The rule is to have three rounds
in a match; each of the horses must be used in one round. The
winner of a single round takes two hundred silver dollars from the
loser."



"Being the most powerful man in the country, the king has so nice
horses that in each class his horse is better than Tian's. As a
result, each time the king takes six hundred silver dollars from
Tian."



"Tian Ji was not happy about that, until he met Sun Bin, one of the
most famous generals in Chinese history. Using a little trick due
to Sun, Tian Ji brought home two hundred silver dollars and such a
grace in the next match."



"It was a rather simple trick. Using his regular class horse race
against the super class from the king, they will certainly lose
that round. But then his plus beat the king's regular, and his
super beat the king's plus. What a simple trick. And how do you
think of Tian Ji, the high ranked official in China?"



C" title="Problem C">



Were Tian Ji lives in nowadays, he will certainly laugh at himself.
Even more, were he sitting in the ACM contest right now, he may
discover that the horse racing problem can be simply viewed as
finding the maximum matching in a bipartite graph. Draw Tian's
horses on one side, and the king's horses on the other. Whenever
one of Tian's horses can beat one from the king, we draw an edge
between them, meaning we wish to establish this pair. Then, the
problem of winning as many rounds as possible is just to find the
maximum matching in this graph. If there are ties, the problem
becomes more complicated, he needs to assign weights 0, 1, or -1 to
all the possible edges, and find a maximum weighted perfect
matching...



However, the horse racing problem is a very special case of
bipartite matching. The graph is decided by the speed of the horses
--- a vertex of higher speed always beat a vertex of lower speed.
In this case, the weighted bipartite matching algorithm is a too
advanced tool to deal with the problem.



In this problem, you are asked to write a program to solve this
special case of matching problem.
 
Input
The input consists of up to 50 test
cases. Each case starts with a positive integer n (n <= 1000) on
the first line, which is the number of horses on each side. The
next n integers on the second line are the speeds of Tian’s horses.
Then the next n integers on the third line are the speeds of the
king’s horses. The input ends with a line that has a single 0 after
the last test case.
 
Output
For each input case, output a line
containing a single number, which is the maximum money Tian Ji will
get, in silver dollars.
 
Sample Input
3
92 83
71
95 87
74
2
20 20
20 20
2
20 19
22 18
0
 
Sample Output
200
0
0
题意:田忌赛马的超级版,田忌和大王赛马,但是相同等级的马谁的能跑还不一定,谁赢就能赢得对方200金币;
解题思路:这道题说是贪心还不如说成一道数学的分类讨论题,就和中学学的分类讨论太像了
1,田忌最快的马要是比大王最快的快,就比一句,田忌胜;
2,田忌最快的马比大王最快的马慢,就用田忌当前马中最慢的马和他比,田忌输;
3,田忌最快的马和大王最快的马速度相同,就要讨论最慢的马;
4,田忌的最慢的马比大王的马快,田忌胜;
5,否则,田忌输;
感悟:妈呀,这几天平均一天一道题的速度确实有点慢哈......马上就到星期天了,就能加快速了;
AC代码(G++
46MS)
#include

#include

#include

#include

#define maxn 1005

using namespace std;

struct  horses

{

    int
speed;

    char
s;

};

bool comp(horses &a,horses&b)

{

   
if(a.speed!=b.speed)

       
return a.speed>b.speed;

    else

       
return a.speed>b.speed;

}

int main()

{

   
//freopen("in.txt", "r", stdin);

    int
n,money=0,tb,te,gb,ge;

    horses
ti[maxn],god[maxn];

   
while(~scanf("%d",&n)&&n)

    {

       
money=0;

       
tb=gb=0;

       
te=ge=n-1;

       
for(int i=0;i

           
scanf("%d",&ti[i].speed);

       
for(int i=0;i

           
scanf("%d",&god[i].speed);

       
sort(&ti[0],&ti[n],comp);

       
sort(&god[0],&god[n],comp);

       
while (tb <= te)

       
{

           
if (ti[te].speed > god[ge].speed)//田忌最快的马比大王的快就赢一局

           
{

               
money++;

               
te--;

               
ge--;

           
}

           
else if (ti[te].speed < god[ge].speed)//田忌最快的马比大王的慢就输一局

           
{

               
money--;

               
te--;

               
gb++;

           
}

           
else//最快的马一样快

           
{

               
if(ti[tb].speed > god[gb].speed)//田忌最慢的马比大王的快就赢一局

               
{

                   
money++;

                   
tb++;

                   
gb++;

               
}

               
else

               
{

                   
if (ti[te].speed < god[gb].speed)//田忌的慢就输

                   
money--;

                   
te--;

                   
gb++;

               
}

           
}

           
//注意:这些最快最慢都是相对于当前还没有进行过比赛的马,每比一次状态转移

           
//一次

      
}

       
printf("%d\n",money*200);

    }

    return
0;

}

Problem C的更多相关文章

  1. 1199 Problem B: 大小关系

    求有限集传递闭包的 Floyd Warshall 算法(矩阵实现) 其实就三重循环.zzuoj 1199 题 链接 http://acm.zzu.edu.cn:8000/problem.php?id= ...

  2. No-args constructor for class X does not exist. Register an InstanceCreator with Gson for this type to fix this problem.

    Gson解析JSON字符串时出现了下面的错误: No-args constructor for class X does not exist. Register an InstanceCreator ...

  3. C - NP-Hard Problem(二分图判定-染色法)

    C - NP-Hard Problem Crawling in process... Crawling failed Time Limit:2000MS     Memory Limit:262144 ...

  4. Time Consume Problem

    I joined the NodeJS online Course three weeks ago, but now I'm late about 2 weeks. I pay the codesch ...

  5. Programming Contest Problem Types

        Programming Contest Problem Types Hal Burch conducted an analysis over spring break of 1999 and ...

  6. hdu1032 Train Problem II (卡特兰数)

    题意: 给你一个数n,表示有n辆火车,编号从1到n,入站,问你有多少种出站的可能.    (题于文末) 知识点: ps:百度百科的卡特兰数讲的不错,注意看其参考的博客. 卡特兰数(Catalan):前 ...

  7. BZOJ2301: [HAOI2011]Problem b[莫比乌斯反演 容斥原理]【学习笔记】

    2301: [HAOI2011]Problem b Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 4032  Solved: 1817[Submit] ...

  8. [LeetCode] Water and Jug Problem 水罐问题

    You are given two jugs with capacities x and y litres. There is an infinite amount of water supply a ...

  9. [LeetCode] The Skyline Problem 天际线问题

    A city's skyline is the outer contour of the silhouette formed by all the buildings in that city whe ...

  10. PHP curl报错“Problem (2) in the Chunked-Encoded data”解决方案

    $s = curl_init(); curl_setopt($s, CURLOPT_POST, true); curl_setopt($s, CURLOPT_POSTFIELDS, $queryStr ...

随机推荐

  1. thinkphp5.0无限极分类及格式化输出

    首先我们来看数据表 从上图中可以发现,中国下有贵州,北京两个子节点,而北京有天安门一个子节点,纽约的子节点是"纽约的子类". 从pid为0看出,中国和纽约是顶级节点. 因为贵州的p ...

  2. BZOJ-1050-[HAOI2006]旅行comf(并查集)

    Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得路径上最 ...

  3. 在JavaScript中使用json.js:Ajax项目之GET请求(同步)

    1.用php编写一个提供数据的响应程序(phpdata.php) <?php $arr=array(1,2,3,4); //将数组编码为JSON格式的数据 $jsonarr=json_encod ...

  4. java学习——java中的反射学习笔记

    Java--reflect 一.Class类的使用 什么是Class类? 1:在面向对象的世界中,万事万物皆对象. java语言中,静态的成员,普通数据类型类是不是对象呢? 是,对象!是类的对象! 类 ...

  5. SQL server2005学习笔记(一)数据库的基本知识、基本操作(分离、脱机、收缩、备份、还原、附加)和基本语法

    在软件测试中,数据库是必备知识,假期闲里偷忙,整理了一点学习笔记,共同探讨. 阅读目录 基本知识 数据库发展史 数据库名词 SQL组成 基本操作 登录数据库操作 数据库远程连接操作 数据库分离操作 数 ...

  6. 使用SQLite做本地数据缓存的思考

    前言 在一个分布式缓存遍地都是的环境下,还讲本地缓存,感觉有点out了啊!可能大家看到标题,就没有想继续看下去的欲望了吧.但是,本地缓存的重要性也是有的! 本地缓存相比分布式缓存确实是比较out和比较 ...

  7. Codeforces Round #420 (Div. 2)

    /*************************************************************************************************** ...

  8. MongoDB数据库的安装、配置和使用

    1.下载安装包   wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.4.7.tgz 2.解压安装包   tar -zxf mo ...

  9. 像 npm 一样在 Andriod 项目中引入 Gradle 依赖

    一.前言 作为 Android 开发人员,有没有羡慕过 node.js 的导入三方库的方式,node.js 社区为开发者准备了一个快速可靠的依赖管理库.这样的依赖管理库,让 node.js 导入依赖库 ...

  10. 【转】wireshark基本用法及过虑规则

    Wireshark 基本语法,基本使用方法,及包过虑规则: 1.过滤IP,如来源IP或者目标IP等于某个IP   例子: ip.src eq 192.168.1.107 or ip.dst eq 19 ...