最大拿牌的得分

假设有个游戏,一列牌有不同分数,但是只能从两头拿 ,拿到最后分数最高的人获胜,假设两个人都是聪明人,求最后的最高分是多少?

思路:递归算法,一个人拿左边牌,另一个人的得分 和拿右边牌 另一个人的得分作比较,只拿让对方得分最小的牌,反过来也是一样,那如果轮到对方拿牌自己也将会拿到最小的分,

两个方法,分别代表A 的最大得分 B的最大得分

private  static int getAMaxPoker(int []arr, int first, int end, boolean aFirst,int total){if(first==end){if(aFirst) {return arr[first];}else{return 0;}}if(aFirst) {int left = arr[first];int otherleft = getAMaxPoker(arr, first + 1, end, false,total-left);int right = arr[end];int otherright = getAMaxPoker(arr, first, end - 1,false,total-right);int lefttotal=left+otherleft;int righttotal=right+otherright;if(lefttotal>righttotal){return lefttotal;}else{return righttotal;}}else{return total- getBMaxPoker(arr,first,end,true,total);}}
private  static int getBMaxPoker(int []arr, int first, int end, boolean bFirst,int total) {if (first == end) {if (bFirst) {return arr[first];} else {return 0;}}if (bFirst) {int left = arr[first];int otherleft = getBMaxPoker(arr, first + 1, end, false,total-left);int right = arr[end];int otherright = getBMaxPoker(arr, first, end - 1, false,total-right);if (left + otherleft > right + otherright) {return left + otherleft;} else {return right + otherright;}}else{return total-getAMaxPoker(arr,first,end,true,total);}}

测试方法:

public static void main(String[] args) {int []arr={1,100,2};int sum=0;for (int i = 0; i < arr.length; i++) {sum+=arr[i];}int maxPoker = getAMaxPoker(arr, 0, arr.length - 1, true,sum);System.out.println((sum-maxPoker)>maxPoker?(sum-maxPoker):maxPoker);}

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

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

相关文章

UE材质Fab Megascans

2025年Bridge里已经不能直接导入资产了&#xff0c;显示GET IT ON FAB 只能在Fab中导入资产&#xff0c; 纹理打包技术从RMA改成了ORM O&#xff1a;AO 环境光遮蔽 R&#xff1a;Roughness 粗糙度 M&#xff1a;Metallic 金属度 在Fab中找到材质&#xff0c;点击Add to P…

前后端本地启动

一、后端启动 1. 项目导入 目标&#xff1a;将后端代码从远程仓库&#xff08;GitHub&#xff09;导入到开发工具中&#xff08;例如 IntelliJ IDEA&#xff09;&#xff0c;方便我们对项目进行编辑和运行。 步骤&#xff1a; 打开 IntelliJ IDEA&#xff08;下文简称 IDEA…

ansible 检查目录大小

检查目录大小 worker_du.yml# ansible-playbook -i hosts worker_du.yml --limit w10 --- - name: 检查目录大小hosts:- w10 # 可以根据需要修改目标主机# 可以添加更多主机tasks:- name: 获取每台主机 /root/worker01 目录大小shell: du -sh /root/worker01/ | awk {print …

【NP-hard问题】NP与NP-hard问题通俗解释

最近在研究NP-hard问题&#xff0c;讲一下自己的对于NP与NP-hard问题的通俗解释 一、NP-Hard 问题是什么意思&#xff1f; 什么是 NP&#xff1f; NP 问题可以理解为「检查答案很容易&#xff0c;但找到答案很难」。 举个例子&#xff1a; 假设你在一个迷宫里&#xff0c;…

【黑灰产】假钱包推广套路

假钱包推广产业链研究 市面上钱包的主要推广方式&#xff1a; 1&#xff0c;竞价&#xff08;搜索引擎&#xff09;&#xff0c;误导客户为真正官方钱包从而完成下载使用 优点&#xff1a;精准&#xff0c;客户大 缺点&#xff1a;竞价户容易挂&#xff0c;投资大 2&#xff0…

C#范围表达式,模式匹配,逆变和协变--11

目录 一.范围表达式 1.概述 2.语法 3.代码示例 4.实现原理 5.应用场景 二.模式匹配 1.概述 2.核心概念 3.常用模式类型 4.Switch表达式 5.使用示例 6.优势 三.逆变和协变 1.概述 2.泛型类型参数的变性 3.协变示例 4.逆变示例 5.注意事项 6.应用场景 总结 一…

ollama教程(window系统)

前言 在《本地大模型工具哪家强&#xff1f;对比Ollama、LocalLLM、LM Studio》一文中对比了三个常用的大模型聚合工具优缺点&#xff0c;本文将详细介绍在window操作系统下ollama的安装和使用。要在 Windows 上安装并使用 Ollama&#xff0c;需要依赖 NVIDIA 显卡&#xff0c…

代码随想录 字符串 test1

344. 反转字符串 - 力扣&#xff08;LeetCode&#xff09; 依次交换首尾。 class Solution { public:void reverseString(vector<char>& s) {int h,l;//首尾指针for(h 0, l s.size() - 1; h < s.size() / 2; h, l--){swap(s[h], s[l]);}return ;} };

[论文阅读] (35)TIFS24 MEGR-APT:基于攻击表示学习的高效内存APT猎杀系统

《娜璋带你读论文》系列主要是督促自己阅读优秀论文及听取学术讲座&#xff0c;并分享给大家&#xff0c;希望您喜欢。由于作者的英文水平和学术能力不高&#xff0c;需要不断提升&#xff0c;所以还请大家批评指正&#xff0c;非常欢迎大家给我留言评论&#xff0c;学术路上期…

半导体数据分析: 玩转WM-811K Wafermap 数据集(三) AI 机器学习

前面我们已经通过两篇文章&#xff0c;一起熟悉了WM-811K Wafermap 数据集&#xff0c;并对其中的一些数据进行了调用&#xff0c;生成了一些统计信息和图片。今天我们接着继续往前走。 半导体数据分析&#xff1a; 玩转WM-811K Wafermap 数据集&#xff08;二&#xff09; AI…

BGP 泄露

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 目录 1. BGP 是什么&#xff1f; 2. 什么是 BGP 泄露&#xff1f; 3. 今天发生了什么&#xff1f; 4. 正常和被劫持状态下的路由示意图 5. 受影响区域 6. 责任在谁&#xff1f; 7. 有办法避免这…

wireshark排除私接小路由

1.wireshark打开&#xff0c;发现了可疑地址&#xff0c;合法的地址段DHCP是192.168.100.0段的&#xff0c;打开后查看发现可疑地址段&#xff0c;分别是&#xff0c;192.168.0.1 192.168.1.174 192.168.1.1。查找到它对应的MAC地址。 ip.src192.168.1.1 2.通过show fdb p…

【Ubuntu与Linux操作系统:十一、Java与Android应用开发】

第11章 Java与Android应用开发 11.1 Java开发 Java是一种广泛使用的面向对象编程语言&#xff0c;以其平台无关性和强大的生态系统而闻名。它在Android开发中占据重要地位&#xff0c;同时也是企业级应用和服务器开发的首选语言。 1. Java语言的特点 跨平台性&#xff1a;Ja…

数据库序列的使用、常见场景与优劣势分析

在现代数据库系统中&#xff0c;唯一标识符&#xff08;如主键&#xff09;是数据表中不可或缺的一部分。为了确保主键的唯一性&#xff0c;数据库提供了多种方式来生成这些标识符。其中&#xff0c;数据库序列&#xff08;Sequence&#xff09; 是一种常用且灵活的生成唯一值的…

Rabbit Rocket kafka 怎么实现消息有序消费和延迟消费的

在消息队列系统中&#xff0c;像 RabbitMQ、RocketMQ 和 Kafka 这样的系统&#xff0c;都支持不同的方式来实现消息的有序消费和延迟消费。下面我们分别探讨这些系统中如何实现这两种需求&#xff1a; 1. RabbitMQ&#xff1a;实现消息有序消费和延迟消费 有序消费&#xff1…

Cesium加载地形

Cesium的地形来源大致可以分为两种&#xff0c;一种是由Cesium官方提供的数据源&#xff0c;一种是第三方的数据源&#xff0c;官方源依赖于Cesium Assets&#xff0c;如果设置了AccessToken后&#xff0c;就可以直接使用Cesium的地形静态构造方法来获取数据源CesiumTerrainPro…

kafka原理解析

一、基本概念与架构 消息&#xff08;Message&#xff09;&#xff1a;Kafka 中传递的数据单元&#xff0c;由消息头&#xff08;可选&#xff09;和消息体组成&#xff0c;消息体中包含了实际要传递的业务数据&#xff0c;例如用户的交易记录、日志信息等&#xff0c;通常以字…

26_Redis RDB持久化

从这个模块开始带领大家来学习Redis分布式缓存的相关内容,主要学习目标见下: 数据丢失问题:实现Redis数据持久化(RDB和AOF)并发能力问题:搭建Redis主从集群,实现读写分离故障恢复问题:利用Redis哨兵模式,实现健康检测和自动恢复存储能力问题:搭建Redis分片集群,利用…

使用 CompletableFuture 实现异步编程

在现代 Java 开发中&#xff0c;异步编程是一项重要技能。而 CompletableFuture 是从 Java 8 开始提供的一个功能强大的工具&#xff0c;用于简化异步任务的编写和组合。本文将详细介绍 CompletableFuture 的基本使用和一些常见的应用场景。 1. 为什么选择 CompletableFuture&…

操作系统进程同步

目录 1 进程同步的基本概念 1.1 进程同步概念的引入 1.1.1 两种形式的制约关系 1.1.2 临界资源 1.2 临界区问题 2 信号量机制 2.1 信号量机制介绍 2.1.1 整型信号量 2.1.2 记录型信号量 2.1.3 AND 型信号量 2.1.4 信号量集 2.2 信号量的应用 3 管程机制 3.1 管程…