题目描述
牛牛为了让牛妹崇拜他,决定和牛妹进行石头剪刀布游戏。
当然,普通的石头剪刀布根本吸引不到牛妹,也无法展现牛牛高超的能力,所以牛牛想起了他在一本漫画中看到的规则,游戏规则如下:
两个人进行石头剪刀布大战,开始时会发给每个人n张牌,然后两人进行n次剪刀石头布大战,每一次两人分别选择自己的n张牌中的一张,打出,每张牌只能用一次。
牛牛这个游戏已经玩到了出神入化的地步,以至于他能猜到每一次牛妹会出什么牌。请问在知道牛妹每一轮出什么牌的情况下,牛牛最多能赢多少局比赛?
开始发给牛牛的n张牌里,有p1张石头牌,q1张剪刀牌,m1张布牌。
开始发给牛妹的n张牌里,有p2张石头牌,q2张剪刀牌,m2张布牌。
请返回牛牛能赢的最多局数。
题目分析
题目问牛牛最多能赢多少局,那么我们假设每次都让牛牛赢,那么只需要判断对应牛妹的牌数,然后从两个数里面取一个最小值,然后把三种情况都相加一下就是最终的答案,这个题目的思路就是短板效应
class Solution { public: /** * 请返回牛牛能赢的最多局数 * @param n int整型 * @param p1 int整型 * @param q1 int整型 * @param m1 int整型 * @param p2 int整型 * @param q2 int整型 * @param m2 int整型 * @return int整型 */ int Mostvictories(int n, int p1, int q1, int m1, int p2, int q2, int m2) { int ans1=min(p1,q2); int ans2=min(q1,m2); int ans3=min(m1,p2); return ans1+ans2+ans3; } };