[NOIP2010 普及组] 三国游戏

题目描述

小涵很喜欢电脑游戏,这些天他正在玩一个叫做《三国》的游戏。

在游戏中,小涵和计算机各执一方,组建各自的军队进行对战。游戏中共有 N N N 位武将( N N N为偶数且不小于 4 4 4),任意两个武将之间有一个“默契值”,表示若此两位武将作为一对组合作战时,该组合的威力有多大。游戏开始前,所有武将都是自由的(称为自由武将,一旦某个自由武将被选中作为某方军队的一员,那么他就不再是自由武将了),换句话说,所谓的自由武将不属于任何一方。

游戏开始,小涵和计算机要从自由武将中挑选武将组成自己的军队,规则如下:小涵先从自由武将中选出一个加入自己的军队,然后计算机也从自由武将中选出一个加入计算机方的军队。接下来一直按照“小涵→计算机→小涵→……”的顺序选择武将,直到所有的武将被双方均分完。然后,程序自动从双方军队中各挑出一对默契值最高的武将组合代表自己的军队进行二对二比武,拥有更高默契值的一对武将组合获胜,表示两军交战,拥有获胜武将组合的一方获胜。

已知计算机一方选择武将的原则是尽量破坏对手下一步将形成的最强组合,它采取的具体策略如下:任何时刻,轮到计算机挑选时,它会尝试将对手军队中的每个武将与当前每个自由武将进行一一配对,找出所有配对中默契值最高的那对武将组合,并将该组合中的自由武将选入自己的军队。 下面举例说明计算机的选将策略,例如,游戏中一共有 6 6 6个武将,他们相互之间的默契值如下表所示:

双方选将过程如下所示:

小涵想知道,如果计算机在一局游戏中始终坚持上面这个策略,那么自己有没有可能必胜?如果有,在所有可能的胜利结局中,自己那对用于比武的武将组合的默契值最大是多少?

假设整个游戏过程中,对战双方任何时候均能看到自由武将队中的武将和对方军队的武将。为了简化问题,保证对于不同的武将组合,其默契值均不相同。

输入格式

共 N 行。

第一行为一个偶数 N N N,表示武将的个数。

第 $2 $行到第 $N 行 里 , 第 行里,第 行里,第i+1 行 有 行有 行有N_i 个 非 负 整 数 , 每 两 个 数 之 间 用 一 个 空 格 隔 开 , 表 示 个非负整数,每两个数之间用一个空格隔开,表示 个非负整数,每两个数之间用一个空格隔开,表示 i 号 武 将 和 号武将和 号武将和 i+1,i+2,…,N $号武将之间的默契值( 0 ≤ 0≤ 0≤默契值 ≤ 1 , 000 , 000 , 000 ≤1,000,000,000 ≤1,000,000,000)。

输出格式

共 1 1 1 或 $2 $行。

若对于给定的游戏输入,存在可以让小涵获胜的选将顺序,则输出$ 1$,并另起一行输出所有获胜的情况中,小涵最终选出的武将组合的最大默契值。如果不存在可以让小涵获胜的选将顺序,则输出 0 0 0。

样例 #1

样例输入 #1

6
5 28 16 29 27
23 3 20 1
8 32 26
33 11
12

样例输出 #1

1
32

思路:本题中计算机每次都是取比人小的次最大值,人也同样只能取次最大值,因为人先选,所以人所选的默契值肯定大于计算机选的,所以人肯定能赢(不会输出0),通过找次最大值中的最大就是人所能选的武将默契最大值。

代码:

#include <bits/stdc++.h>
using namespace std;
int n, arr[501][501] = {}, Max = 0;int main()
{cin >> n;for (int i = 1;i < n;i++){for (int j = i + 1;j <= n;j++){cin >> arr[i][j];                       //匹配度arr[j][i] = arr[i][j];}}for (int i = 1;i <= n;i++){int Mymax = 0, Cmax = 0;                     //Cmax为次最大值for (int j = 1;j <= n;j++){if (Mymax < arr[i][j]){Cmax = Mymax;Mymax = arr[i][j];}elseCmax = max(Cmax, arr[i][j]);Max = max(Cmax, Max);                 //取最大的次最大值}}cout << "1" << endl;cout << Max;return 0;
}

三国游戏(贪心算法)相关推荐

  1. 161. Leetcode 55. 跳跃游戏 (贪心算法-贪心区间)

    class Solution:def canJump(self, nums: List[int]) -> bool:if len(nums) == 1:return Truecover = 0i ...

  2. [Leedcode][JAVA][第45题][跳跃游戏 II][贪心算法]

    [问题描述][Leedcode][JAVA][第45题][跳跃游戏 II] 输入: [2,3,1,1,4] 输出: 2 解释: 跳到最后一个位置的最小跳跃数是 2.从下标为 0 跳到下标为 1 的位置 ...

  3. 贪心算法——国王游戏

    题目描述 孙悟空给花果山的小猴子们分桃子. 首先,他让每只小猴在左.右手上面分别写下一个整数,悟空自己也在左.右手上各写一个整数. 然后,让这 n 只小猴排成一排,悟空站在队伍的最前面. 排好队后,所 ...

  4. _28LeetCode代码随想录算法训练营第二十八天-贪心算法 | 122.买卖股票的最佳时机II 、55.跳跃游戏、45.跳跃游戏II

    _28LeetCode代码随想录算法训练营第二十八天-贪心算法 | 122.买卖股票的最佳时机II .55.跳跃游戏.45.跳跃游戏II 题目列表 122.买卖股票的最佳时机II 55.跳跃游戏 45 ...

  5. 国王游戏(贪心算法+高精度运算)

    恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏. 首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数. 然后,让这 n 位大臣排成一排,国王站在队伍的最前面. ...

  6. 贪心算法很简单:跳跃游戏

    题目描述: 定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 判断你是否能够到达最后一个位置. 示例 1: 输入: [2,3,1,1,4] 输出: ...

  7. P1199 [NOIP2010 普及组] 三国游戏-博弈论+贪心

    [NOIP2010 普及组] 三国游戏 题目描述 小涵很喜欢电脑游戏,这些天他正在玩一个叫做<三国>的游戏. 在游戏中,小涵和计算机各执一方,组建各自的军队进行对战.游戏中共有 N N N ...

  8. C++算法篇 贪心算法

    实际生活中,经常需要求一些问题的"可行解"和"最优解",这就是所谓的"最优化"问题.一般来说,每个最优化问题都包含一组"限制条件& ...

  9. 总结 贪心算法_这几道经典例题帮你轻松搞透贪心算法

    贪心算法概念叙述 运用贪心算法求解问题时,会将问题分为若干个子问题,可以将其想象成俄罗斯套娃,利用贪心的原则从内向外依次求出当前子问题的最优解,也就是该算法不会直接从整体考虑问题,而是想要达到局部最优 ...

最新文章

  1. QTP中使用ExecuteFile加载vbs脚本
  2. JAVA线程池管理及分布式HADOOP调度框架搭建
  3. Error:Cannot set the value of read-only property 'outputFile' for ApkVariantOutputImpl_Decorated{apk
  4. Unity学习笔记3 简易2D横版RPG游戏制作(三)
  5. felzenszwalb算法_学习图像场景解析的理论和应用(二)场景解析的经典算法分析之SLIC...
  6. “睡服”面试官系列第二十一篇之class基本语法(建议收藏学习)
  7. vlc文件服务器局域网,vlc流媒体服务器配置
  8. ACM Robot Motion
  9. Hadoop HIVE 安装配置(单机集群)
  10. 南京铁道学院计算机应用,南京铁道职业技术学院铁道交通运营管理专业
  11. 深夜十点,北京各大互联网企业的下班高峰才刚开始?北晚记者带您实地探访...
  12. DbUtils组件的使用小指南
  13. Autodesk Maya 2009标准培训教材
  14. 纬创软件本社对日JAVA开发
  15. Python:使用nltk统计词频并绘制统计图
  16. 把 汇编代码翻译成二进制机器代码
  17. 迪杰斯特拉算法(邻接表求解)
  18. Koa koa-combine-routers 分路由管理
  19. python网页自动填写_Windows下使用python3 + selenium实现网页自动填表功能
  20. 我的世界服务器java出错_看懂 游戏《Minecraft》的崩溃报告 服务端/客户端

热门文章

  1. wps如何设置试卷密封线_wps试卷密封线怎么做
  2. 南邮通达计科软件工程考试2022.1
  3. java1.7线程暂停_Java实现多线程断点下载实例代码(下载过程中可以暂停)
  4. 涨知识!java程序设计第二版课后答案雍俊海
  5. 【转载】写给电子信息工程专业的毕业生(一)
  6. 西门子Wincc+S7-300污水处理大项目 带西门子Wincc上位机+S7-300程序
  7. 污水处理系统 | 污水处理项目
  8. mac安装淘宝镜像cnpm
  9. tplinkac2600评测_千兆双频家庭路由器测评之:华为、小米、小k云管家、TP-LINK
  10. win10 vs2019 tensorRT7 yolov5配置