POJ 2287 田忌赛马(贪心)

文章目录

    • 1. 题目
      • 1.1 题目链接
      • 1.2 题目大意
      • 1.3 解题思路
    • 2. Accepted 代码

1. 题目

1.1 题目链接

http://poj.org/problem?id=2287

1.2 题目大意

双方各有n匹战斗力各异的马,分别派出来PK,假设对方先出牌,我方后出,求我方最多能胜几场

1.3 解题思路

  • 对方出来战斗力k的马
  • 我方派出战斗力比k大的且最弱的马,赢,保存实力更高的马
  • 若均无法战胜对方,派出最弱的马,让你赢个最弱的,保存实力

2. Accepted 代码

在这里插入图片描述

/*** @description: poj2287田忌赛马(贪心)* @author: michael ming* @date: 2019/7/2 23:55* @modified by: */
#include <iostream>
#include <algorithm>
using namespace std;
bool comp(int a, int b)
{return a > b;
}
int main()
{int i, j, iend, jend, n, money;int tianji[1001], king[1001];while(cin >> n && n != 0){for(i = 0; i < n; ++i)cin >> tianji[i];for(j = 0; j < n; ++j)cin >> king[j];sort(tianji, tianji+n, comp);//从大到小排序sort(king, king+n, comp);//从大到小排序i = j = 0;iend = jend = n-1;money = 0;while(i <= iend){if(tianji[i] > king[j])//我方能打赢所有的,那么我就打掉一个最厉害的{money += 200;i++,j++;}else if(tianji[i] < king[j])//我方最大的都比别人小,让最弱的出战{money -= 200;iend--,j++;}else//两边最厉害的一样{if(tianji[iend] > king[jend])//最弱的马都能打败你的最弱马,那就用最小实力的{money += 200;iend--,jend--;}else if(tianji[iend] < king[jend])//我最弱的马没有胜算,让给你最强的马吃掉{money -= 200;iend--,j++;}else//两边最厉害的,和最弱的都一样,{if(tianji[iend] < king[j])money -= 200;//我最弱的给你最强的吃掉iend--,j++;//如果tianji[iend] == king[j]//说明剩余两边的马全部相等,打平,金钱不变,下标挪一下}}}cout << money << endl;}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/480156.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Netty的实现原理、特点与优势、以及适用场景

高并发编程系列 高并发编程系列&#xff1a;NIO、BIO、AIO的区别&#xff0c;及NIO的应用和框架选型 高并发编程系列&#xff1a;ConcurrentHashMap的实现原理(JDK1.7和JDK1.8) 高并发编程系列&#xff1a;CountDownLatch、Semaphore等4大并发工具类详解 高并发编程系列&…

拒绝无脑吹!从ACL20看预训练缺陷

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 舒意恒、兔子酱以 BERT 为代表作的预训练模型的研究热度一直很高&#xff0c;到 0202 年了&#xff0c;预训练的研究依旧层出不穷&#xff0c;而且 ACL 2020 Best Paper 荣誉提名也选择了这一主题的研究…

论文浅尝 | AMUSE: 基于 RDF 数据的多语言问答语义解析方法

来源&#xff1a;ISWC 2017链接&#xff1a;https://link.springer.com/content/pdf/10.1007%2F978-3-319-68288-4.pdf本文主要关注基于RDF数据的多语言问答任务中&#xff0c;对不同语言问句的语义分析工作。作者提出一种基于DUDES(Dependency-based Underspecified Discourse…

贪心应用--汽车加油次数问题

文章目录1. 问题描述2. 解题思路3. 实现代码4. 测试结果1. 问题描述 已知汽车的油箱额定里程&#xff0c;到目的地的路途中各加油站距起点的距离&#xff0c;求如何加油&#xff0c;让加油的次数最少。 2. 解题思路 每次出发前检查下一个加油站有多远&#xff0c;车子能不能…

最全多线程经典面试题和答案

Java实现线程有哪几种方式&#xff1f; 1、继承Thread类实现多线程2、实现Runnable接口方式实现多线程3、使用ExecutorService、Callable、Future实现有返回结果的多线程 多线程同步有哪几种方法&#xff1f; Synchronized关键字&#xff0c;Lock锁实现&#xff0c;分布式锁等…

论文浅尝 | Aligning Knowledge Base and Document Embedding Models

本文是我们于苏黎世大学合作的关注与知识图谱和文本对齐的论文&#xff0c;发表于ISWC2018.文本和知识图谱都包含了丰富的信息, 其中知识图谱用结构化的三元组表示信息&#xff0c;文本用自由文本形式表示信息&#xff0c;信息表示的差异给知识图谱和文本融合对齐造成了困难&am…

学会提问的BERT:端到端地从篇章中构建问答对

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 苏剑林机器阅读理解任务&#xff0c;相比不少读者都有所了解了&#xff0c;简单来说就是从给定篇章中寻找给定问题的答案&#xff0c;即“篇章 问题 → 答案”这样的流程&#xff0c;笔者之前也写过一些…

玩转算法面试-第四章查找值之leetcod相关笔记

查找问题 4-1,2 两类查找问题 1 查找有无&#xff1a;set 2 查找对应关系&#xff1a;map 常见的四种操作&#xff1a; insert&#xff0c; find&#xff0c; erase&#xff0c; change&#xff08;map&#xff09; 例题 leetcode 349 &#xff1a;给定两个数组&#xff0c;…

分治算法(Divide Conquer)

文章目录1. 分治算法思想2. 应用举例2.1 逆序度3. 分治思想处理海量数据1. 分治算法思想 分治算法的核心思想就是&#xff0c;分而治之&#xff0c;将原问题划分成n个规模较小&#xff0c;并且结构与原问题相似的子问题&#xff0c;递归地解决这些子问题&#xff0c;然后再合并…

史上最全Java多线程面试60题,含答案大赠送!

【BAT必考系列&#xff01;多线程60题】 多线程有什么用&#xff1f; 线程和进程的区别是什么&#xff1f; ava实现线程有哪几种方式&#xff1f; 启动线程方法start&#xff08;&#xff09;和run&#xff08;&#xff09;有什么区别&#xff1f; 怎么终止一个线程&#…

论文浅尝 | Interaction Embeddings for Prediction and Explanation

本文是我们与苏黎世大学合作的工作&#xff0c;将发表于WSDM2019&#xff0c;这篇工作在知识图谱的表示学习中考虑了实体和关系的交叉交互&#xff0c;并且从预测准确性和可解释性两个方面评估了表示学习结果的好坏。给定知识图谱和一个要预测的三元组的头实体和关系&#xff0…

商汤科技-数据运维工程师-提前批笔试题目汇总

2019年8月19日 问答题1&#xff1a;缺失值数据预处理有哪些方法&#xff1f;https://juejin.im/post/5b5c4e6c6fb9a04f90791e0c 处理缺失值的方法如下&#xff1a;删除记录&#xff0c;数据填补和不处理。主要以数据填补为主。 1 删除记录&#xff1a;该种方法在样本数据量十分…

秋招视频攻略!13个offer,8家SSP的Q神谈算法岗秋招技巧

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术大家还记得几个月前卖萌屋Q神推送的那期《13个offer&#xff0c;8家SSP&#xff0c;谈谈我的秋招经验》吗&#xff1f;据说Q神掌握了影分身的话&#xff0c;一毕业就能年薪600万&#xff0c;咳咳。。。ps&…

分治应用--最近点对问题 POJ 3714

文章目录1. 问题描述2. 解题思路3. 实现代码4. POJ 37141. 问题描述 二维平面上有n个点&#xff0c;如何快速计算出两个距离最近的点对&#xff1f; 2. 解题思路 暴力做法是&#xff0c;每个点与其他点去计算距离&#xff0c;取最小的出来&#xff0c;复杂度O(n2)采用分治算…

Java多线程系列(十):源码剖析AQS的实现原理

在并发编程领域&#xff0c;AQS号称是并发同步组件的基石&#xff0c;很多并发同步组件都是基于AQS实现&#xff0c;所以想掌握好高并发编程&#xff0c;你需要掌握好AQS。 本篇主要通过对AQS的实现原理、数据模型、资源共享方式、获取锁的过程&#xff0c;让你对AQS的整体设计…

玩转二算法课的笔记-第一章

1 问题&#xff1a;对一组数据进行排序 回答&#xff1a;快速排序算法o(NLOGN)&#xff0c;错误。 关键词&#xff1a;思考 应该问面试官&#xff0c;这组数据有什么样的特征&#xff1f; 比如;有没有可能包含大量重复的元素&#xff1f; 如果有这个可能的话&#xff0c;三路快…

微软亚洲研究院NLC组招聘实习生!与一线研究员共探NLP前沿与落地!

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术MSRA-NLC组招人啦&#xff01;微软亚洲研究院&#xff08;MSRA&#xff09;自然语言计算组&#xff08;NLC&#xff09;招收长期实习生一名&#xff0c;与一线研究员共同进行自然语言处理领域的科研项目和落地…

分治应用--万里挑一 找假硬币

文章目录1. 问题描述2. 解题思路3. 代码实现1. 问题描述 n 个硬币中有1枚是假币&#xff0c;真假币唯一的区别是假币重量轻&#xff0c;如何快速找出假币 2. 解题思路 暴力做法&#xff0c;一个一个的称重&#xff0c;O&#xff08;n&#xff09;复杂度分治思路 将硬币等分…

Java多线程与并发系列从0到1全部合集,强烈建议收藏!

在过去的时间中&#xff0c;我写过Java多线程与并发的整个系列。 为了方便大家的阅读&#xff0c;也为了让知识更系统化&#xff0c;这里我单独把Java多线程与并发的整个系列一并罗列于此&#xff0c;希望对有用的人有用&#xff0c;也希望能帮助到更多的人。 以下为整个目录&a…

论文浅尝 | 基于图注意力的常识对话生成

OpenKG 祝各位读者新春快乐&#xff0c;猪年吉祥&#xff01;来源&#xff1a;IJCAI 2018.论文下载地址&#xff1a;https://www.ijcai.org/proceedings/2018/0643.pdf项目源码地址&#xff1a;https://github.com/tuxchow/ccm动机在以前的工作中&#xff0c;对话生成的信息源是…