Leetcode1686. 石子游戏 VI

Every day a Leetcode

题目来源:1686. 石子游戏 VI

解法1:贪心 + 排序

贪心的思想:

在这里插入图片描述

这道题模拟一个石子游戏,求解最后的比赛结果。

题目说两位玩家都会采用 最优策略 进行游戏,那么关键点就在于什么是最优策略?

是每次都取走自己能取的最大得分吗?并不是!

作为玩家,我们的目标不仅是自己得分高,而且同时要对手得分低。因此玩家每次选择的是那些 双方得分都高的石子,在自己得分高的同时使得对方的得分无法提高。因此我们可以根据每个石子的价值和进行排序,两位玩家依次取走综合得分高的石子。

我们只需要将两个数组 aliceValues 和 bobValues 对应的元素相加后倒序排序,然后 Alice 和 Bob 依次选取,最后计算两人的分数和后进行比较返回结果。

代码:

/** @lc app=leetcode.cn id=1686 lang=cpp** [1686] 石子游戏 VI*/// @lc code=start
class Solution
{
public:int stoneGameVI(vector<int> &aliceValues, vector<int> &bobValues){int n = aliceValues.size();vector<int> idx(n);iota(idx.begin(), idx.end(), 0);sort(idx.begin(), idx.end(), [&aliceValues, &bobValues](const int lhs, const int rhs){ return (aliceValues[lhs] + bobValues[lhs]) > (aliceValues[rhs] + bobValues[rhs]); });int alice_score = 0, bob_score = 0;for (int i = 0; i < n; i++){if (i % 2 == 0) // Alice choosealice_score += aliceValues[idx[i]];else // Bob choosebob_score += bobValues[idx[i]];}if (alice_score == bob_score)return 0;return alice_score > bob_score ? 1 : -1;}
};
// @lc code=end

结果:

在这里插入图片描述

复杂度分析:

时间复杂度:O(nlogn),其中 n 是数组 aliceValues / bobValues 的元素个数。

空间复杂度:O(n),其中 n 是数组 aliceValues / bobValues 的元素个数。

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

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

相关文章

Swift Combine 合并多个管道以更新 UI 元素 从入门到精通十七

Combine 系列 Swift Combine 从入门到精通一Swift Combine 发布者订阅者操作者 从入门到精通二Swift Combine 管道 从入门到精通三Swift Combine 发布者publisher的生命周期 从入门到精通四Swift Combine 操作符operations和Subjects发布者的生命周期 从入门到精通五Swift Com…

Java 8中的Stream API是什么?

Java 8引入了一项强大的新抽象称为Stream API&#xff0c;旨在提高Java程序员在处理集合时的生产力。它是为了使集合的操作更加方便和高效&#xff0c;尤其是对于大数据集的处理。Stream API通过提供一种高级的、声明式编程方式来处理数据&#xff0c;允许对数据进行复杂的查询…

centos中docker操作+安装配置django+mysql5.7并使用simpleui美化管理后台

一、安装docker 确保系统是CentOS 7并且内核版本高于3.10,可以通过uname -r命令查看内核版本。 更新系统软件包到最新版本,可以使用命令yum update -y。 安装必要的软件包,包括yum-utils、device-mapper-persistent-data和lvm2。使用命令yum install -y yum-utils devic…

软考 系统分析师系列知识点之信息系统战略规划方法(11)

接前一篇文章&#xff1a;软考 系统分析师系列知识点之信息系统战略规划方法&#xff08;10&#xff09; 所属章节&#xff1a; 第7章. 企业信息化战略与实施 第4节. 信息系统战略规划方法 7.4.7 价值链分析法 价值链分析&#xff08;Value Chain Analysis&#xff0c;VCA&am…

.NET Core MongoDB数据仓储和工作单元模式封装

前言 上一章我们把系统所需要的MongoDB集合设计好了&#xff0c;这一章我们的主要任务是使用.NET Core应用程序连接MongoDB并且封装MongoDB数据仓储和工作单元模式&#xff0c;因为本章内容涵盖的有点多关于仓储和工作单元的使用就放到下一章节中讲解了。仓储模式&#xff08;R…

两年前的爱爱竟然让她染上菜花和梅毒!医师警告:性病潜伏期不可小觑,HPV疫苗是必备的

【记者许家源/综合报道】 台北市一名30多岁的女性&#xff0c;因为私密处长出不明物体&#xff0c;到泌尿科求诊&#xff0c;没想到被诊断出是菜花&#xff0c;而且还合并了梅毒。 她回想起自己最后一次发生性关系&#xff0c;竟然是两年前和前男友的事&#xff0c;不明白为什…

搭建 blender python api 的外部开发环境

以下都是为了不直接在 blender 的 script ide 里写脚本而做&#xff0c;直接在 blender 里写的话就没什么参考意义了。 首先是2个blender的设置选项&#xff0c;建议开启&#xff0c;会比较方便。 开发选项启用后&#xff0c;你在一些菜单上右键的话&#xff0c;会多出来 在线…

国内几个做的不错的研发效能度量工具

国内几个做的不错的研发效能度量工具&#xff1a; 1、PingCode https://sc.pingcode.com/uvo4u 2、思码逸 https://www.merico.cn 3 云效 https://www.aliyun.com/product/yunxiao/ 4、 Ones https://ones.cn/ 其中思码逸还是不错的&#xff0c;可以接入各种如禅道呀&a…

CleanMyMac X2024版本有哪些常见的使用场景?

CleanMyMac X作为一款Mac电脑清理和优化工具&#xff0c;具有多种使用场景。以下是一些常见的使用场景&#xff1a; 清理系统垃圾文件&#xff1a;CleanMyMac X可以智能扫描Mac磁盘空间&#xff0c;清理系统冗余文件和各种软件应用产生的垃圾文件&#xff0c;如缓存、日志文件…

Kotlin基础——类、对象和接口

文章目录 1 定义类继承结构1.1 接口1.1.1 接口概述1.1.2 接口中的默认方法1.1.3 接口方法重复1.1.4 Kotlin接口中静态方法实现原理 1.2 修饰符1.2.1 类继承修饰1.2.2 方法重写修饰1.2.3 抽象类1.2.4 接口的修饰符 1.3 可见性修饰符1.3.1 Kotlin中的可见性修饰符1.3.2 Kotlin中的…

记 proxifier

5EZ8G-C3WL5-B56YG-SCXM9-6QZAP

男人圣经 2

男人圣经&#x1f4d5; 2 强文喾哲改观制衡 功臣 强文 过去我学的思想都是真善美、好人就会有好报、有好名声等等。 真实世界其实是 强者才会有好报、世界上所有的好东西都是给强者准备的、世界法则就是奖励强者、惩罚弱者。 强者的根本属性是强势文化&#xff0c;和常人的思…

林浩然与杨凌芸的时空约会奇遇记

林浩然与杨凌芸的时空约会奇遇记 The Time-Traveling Love Story of Lin Haoran and Yang Lingyun in the Java World 在那个阳光明媚、Java代码飞舞的日子里&#xff0c;程序员界的“情圣”林浩然和美丽聪明的数据分析师杨凌芸携手演绎了一场跨越时间与空间的爱情故事&#xf…

ZYNQ:PL-CAN总线功能应用

流程背景 前期基本实现PS端的CAN总线功能&#xff0c;现阶段的主要目的是实现PL端的CAN总线功能&#xff0c;需要采用CAN IP。 PL系统搭建 PL外设时钟源 搭建完vivado系统后&#xff0c;需要在sdk编程。但是在配置PL&#xff0d;CAN时&#xff0c;意识到CAN时钟值不清楚&…

蓝桥省赛真题|简单:分数

题目链接&#xff1a;https://www.lanqiao.cn/problems/610/learning/?page1&first_category_id1&second_category_id3&tags2018&name%E5%88%86%E6%95%B0 题不难&#xff0c;但是可以帮助编程时好的习惯的养成&#xff0c;更加注意一些细节。 注意几个地方︰…

《区块链公链数据分析简易速速上手小册》第10章:未来趋势和挑战(2024 最新版)

文章目录 10.1 区块链技术的发展方向10.1.1 基础知识10.1.2 重点案例&#xff1a;构建一个简单的智能合约步骤1: 创建智能合约步骤2: 部署智能合约步骤3: 使用Python与智能合约交互结语 10.1.3 拓展案例 1&#xff1a;探索 DeFi 应用准备工作实现步骤步骤1: 获取Compound市场数…

Python 键盘模拟

本篇文章将通过python程序模拟键盘操作。 引入类库 引入相应类库&#xff0c;示例如下&#xff1a; import win32con import win32api import time 模拟按下抬起 按下0.1秒后抬起。 示例如下&#xff1a; win32api.keybd_event(91, 0, 0, 0) time.sleep(0.1) win32api.key…

2.15:指针习题

一&#xff0e;选择题 1.变量的指针&#xff0c;其含义是指该变量的 B 。 A&#xff09;值 B&#xff09;地址 C&#xff09;名 D&#xff09;一个标志 2.已有定义int k2;int *ptr1,*ptr2;且ptr1和ptr2均已指向变量k&…

Jmeter接口测试实战篇:10分钟学会Jmeter的用法

一提到接口测试&#xff0c;通常大家会有这样的疑问&#xff1a;前端测试不是已经覆盖到各种业务逻辑了吗&#xff1f;为什么还要做接口测试&#xff0c;接口测试和前端测试是不是重复了&#xff1f;对于这个问题&#xff0c;可以从下面几个方面来解释&#xff1a; 什么是接口…

CSS3学习(二)

目录&#xff1a; 1. 字体属性 1.1 字体系列 1.2 字体大小 1.3 字体粗细 1.4 文字样式 1.5 字体复合属性 1.6 总结 2 文本属性 2.1 文本颜色 2.2 对齐文本 2.3 装饰文本 2.4 文本缩进 2.5 行间距 2.6 总结 1. 字体属性 1.1 字体系列 使用font-family属性定义文…