LeetCode 870. 优势洗牌(贪心 二分查找)

1. 题目

给定两个大小相等的数组 A 和 B,A 相对于 B 的优势可以用满足 A[i] > B[i] 的索引 i 的数目来描述。

返回 A 的任意排列,使其相对于 B 的优势最大化。

示例 1:
输入:A = [2,7,11,15], B = [1,10,4,11]
输出:[2,11,7,15]示例 2:
输入:A = [12,24,8,32], B = [13,25,32,11]
输出:[24,32,8,12]提示:
1 <= A.length = B.length <= 10000
0 <= A[i] <= 10^9
0 <= B[i] <= 10^9

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/advantage-shuffle
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 田忌赛马(贪心)

2.1 二分查找

将A排序,对每个Bi ,在A中查找比其大的第一个数

class Solution {int l,r,mid;
public:vector<int> advantageCount(vector<int>& A, vector<int>& B) {sort(A.begin(), A.end());vector<int> ans(A.size());int idx;for(int i = 0; i < B.size(); ++i){idx = binarysearch(A,B[i]);if(idx != -1){ans[i] = A[idx];A.erase(A.begin()+idx);}else//没找到比Bi大的,用最小的{ans[i] = A[0];A.erase(A.begin());}}return ans;}int binarysearch(vector<int>& A, int& n){	//在A中找第一个比n大的l = 0; r = A.size()-1;while(l <= r){mid = l+((r-l)>>1);if(A[mid] > n){if(mid==0 || A[mid-1] <= n)return mid;r = mid-1;}elsel = mid+1;}return -1;}
};

在这里插入图片描述

2.2 排序,双指针

class Solution {
public:vector<int> advantageCount(vector<int>& A, vector<int>& B) {vector<int> ans(A.size());vector<vector<int>> Bval_idx(B.size(),{-1,-1});int n = A.size();for(int i = 0; i < n; ++i){Bval_idx[i][0] = B[i];Bval_idx[i][1] = i;}sort(A.begin(), A.end());sort(Bval_idx.begin(), Bval_idx.end(), [](const auto& a, const auto& b){return a[0] < b[0];});//按数值排序int i = 0, j = n-1, k = 0;for(int k = 0; k < n; ++k){if(A[k] > Bval_idx[i][0])//最小的能打赢你的最小的{ans[Bval_idx[i++][1]] = A[k];}else//最小的不能打赢你们,那么送给你们最大的吃ans[Bval_idx[j--][1]] = A[k];}return ans;}
};

在这里插入图片描述

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

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

相关文章

Spring Cloud构建微服务架构:服务网关(路由配置)【Dalston版】

在上一篇《Spring Cloud构建微服务架构&#xff1a;服务网关&#xff08;基础&#xff09;》一文中&#xff0c;我们通过使用Spring Cloud Zuul构建了一个基础的API网关服务&#xff0c;同时也演示了Spring Cloud Zuul基于服务的自动路由功能。在本文中&#xff0c;我们将进一步…

技术动态 | Neo4j知识图谱的技术解析及案例分享

转载公众号 | DataFunTalk 合作分享&#xff1a;Jesus Barrasa-Neo4j-欧洲区售前和技术总监合作分享&#xff1a;丁可-Neo4j-亚太区高级技术顾问编辑整理&#xff1a;吴祺尧-加州大学圣地亚哥分校出品平台&#xff1a;DataFunTalk导读&#xff1a;Neo4j近年来与众多公司合作&am…

哈工大博士历时半年整理的《Pytorch常用函数函数手册》开放下载!内含200余个函数!...

近期有很多小伙伴在公众号后台咨询有没有关于Pytorch函数使用的学习资料。Pytorch是目前常用的深度学习框架之一&#xff0c;深受学生党的喜爱&#xff0c;小白本人也是使用的Pytorch框架。为了帮助更多小伙伴&#xff0c;小白学视觉团队整理了这份目前最全的Pytorch常用函数手…

LeetCode 984. 不含 AAA 或 BBB 的字符串(贪心)

1. 题目 给定两个整数 A 和 B&#xff0c;返回任意字符串 S&#xff0c;要求满足&#xff1a; S 的长度为 A B&#xff0c;且正好包含 A 个 ‘a’ 字母与 B 个 ‘b’ 字母&#xff1b;子串 ‘aaa’ 没有出现在 S 中&#xff1b;子串 ‘bbb’ 没有出现在 S 中。 示例 1&…

Spring Cloud构建微服务架构:服务网关(基础)【Dalston版】

通过之前几篇Spring Cloud中几个核心组件的介绍&#xff0c;我们已经可以构建一个简略的&#xff08;不够完善&#xff09;微服务架构了。比如下图所示&#xff1a; 我们使用Spring Cloud Netflix中的Eureka实现了服务注册中心以及服务注册与发现&#xff1b;而服务间通过Ribbo…

论文浅尝 | PASSLEAF:基于样本池的不确定性知识图谱嵌入半监督学习框架

笔记整理&#xff1a;陈一林&#xff0c;东南大学硕士&#xff0c;研究方向为不确定性知识图谱规则与推理。论文引用&#xff1a;Citation: Chen, Z.M., Yeh, M.Y. and Kuo, T.W., 2021, May. PASSLEAF: A Pool-bAsed Semi-Supervised LEArning Framework for Uncertain Knowle…

扔掉老破V100、A100,英伟达新一代计算卡H100来了

本文转载自公众号“夕小瑶的卖萌屋”&#xff0c;专业带逛互联网算法圈的神操作 -----》我是传送门 关注后&#xff0c;回复以下口令&#xff1a; 回复【789】 &#xff1a;领取深度学习全栈手册&#xff08;含NLP、CV海量综述、必刷论文解读&#xff09; 回复【入群】&#xf…

LeetCode 725. 分隔链表

1. 题目 给定一个头结点为 root 的链表, 编写一个函数以将链表分隔为 k 个连续的部分。 每部分的长度应该尽可能的相等: 任意两部分的长度差距不能超过 1&#xff0c;也就是说可能有些部分为 null。 这k个部分应该按照在链表中出现的顺序进行输出&#xff0c;并且排在前面的…

会议交流 | 知识工程/知识图谱教学研讨会 暨 知识工程课程群虚拟教研室第一次教学研讨会...

日程安排时 间&#xff1a;2022年10月11日&#xff08;周二&#xff09;19:40-21:00地 点&#xff1a;虚拟教研室&#xff08;B版&#xff09;/ 腾讯会议&#xff1a;287 808 963主持人&#xff1a;知识工程课程群虚拟教研室带头人 天津大学教授 王鑫教学研讨会会议议程&#x…

@FeignClient中的@RequestMapping也被SpringMVC加载的问题解决

问题描述 在之前发布的《Spring Cloud实战小贴士&#xff1a;Feign的继承特性(伪RPC模式)》一文中&#xff0c;我们介绍了如果使用Feign的继承特性来完成服务的提供以及服务的消费&#xff0c;实现了类似RPC的编程模式。但是&#xff0c;仔细一些的读者可能已经发现一个问题&a…

GIF发明者感染新冠后去世,没有他就没有表情包

文 | 金磊 发自 凹非寺源 | 量子位GIF&#xff08;图形交换格式&#xff09;发明人Stephen Wilhite&#xff0c;被曝去世&#xff0c;享年74岁。▲Stephen Wilhite据The Verge表示&#xff0c;在经过与Wilhite的妻子Kathaleen交流之后&#xff0c;确认他是于上周因感染新冠病毒…

LeetCode 1073. 负二进制数相加(负数进制)

1. 题目 给出基数为 -2 的两个数 arr1 和 arr2&#xff0c;返回两数相加的结果。 数字以 数组形式 给出&#xff1a;数组由若干 0 和 1 组成&#xff0c;按最高有效位到最低有效位的顺序排列。例如&#xff0c;arr [1,1,0,1] 表示数字 (-2)3 (-2)2 (-2)0 -3。数组形式 的…

图谱实战 | 真实世界医疗知识图谱及临床事件图谱构建

转载公众号 | DataFunTalk分享嘉宾&#xff1a;李林峰博士 医渡云 技术创新副总裁编辑整理&#xff1a;田育珍 搜狗出品平台&#xff1a;DataFunTalk导读&#xff1a;今天介绍的主题是真实世界医疗知识图谱及临床事件图谱的构建。数据源主要来自于医院的EMR、HIS、LIS、RIS等系…

Spring Cloud实战小贴士:Feign的继承特性(伪RPC模式)

通过之前发布的《Spring Cloud构建微服务架构&#xff1a;服务消费者&#xff08;Feign&#xff09;》&#xff0c;我们已经学会如何使用Spring MVC的注解来绑定服务接口。我们几乎完全可以从服务提供方的Controller中依靠复制操作&#xff0c;来构建出相应的服务接口客户端&am…

这个北航妹子也太卷了...

大家好&#xff0c;今天介绍一位好朋友&#xff0c;毕业于北航的AI算法小姐姐 rumor。rumor刚毕业时从事量化工作&#xff0c;后来转岗到互联网做算法&#xff0c;斩获了众多大厂offer&#xff0c;下面是她跳槽时整理的算法工程师面试知识点&#xff1a;就拿其中的数据结构节点…

LeetCode 1138. 字母板上的路径

1. 题目 我们从一块字母板上的位置 (0, 0) 出发&#xff0c;该坐标对应的字符为 board[0][0]。 在本题里&#xff0c;字母板为board [“abcde”, “fghij”, “klmno”, “pqrst”, “uvwxy”, “z”]. 我们可以按下面的指令规则行动&#xff1a;如果方格存在&#xff0c;U…

开源开放 | 中药说明书实体识别数据集TCM-NER

OpenKG地址&#xff1a;http://openkg.cn/dataset/tcm-ner阿里云天池&#xff1a;https://tianchi.aliyun.com/dataset/dataDetail?dataId86819开放许可协议&#xff1a;CC BY-SA 4.0 &#xff08;署名相似共享&#xff09;贡献者&#xff1a;阿里云&#xff08;陈漠沙&#x…

【公益】开放一台Eureka注册中心给各位Spring Cloud爱好者

这是一篇博客福利&#xff01; 相信很多关注Spring Cloud的爱好者们&#xff0c;不论是读我的系列文章和书籍还是看其他朋友们写的博客佳文&#xff0c;都不可避免的启动多个项目来体验Spring Cloud带来的整套微服务架构方案。其中&#xff0c;Eureka注册中心几乎是每个试验都必…

首个视觉-语言预训练综述来了!

文 | Feilong Chen等编 | 陈萍源 | 机器之心一文了解视觉 - 语言预训练最新进展和新领域。让机器做出与人类相似的反应一直是 AI 研究不懈追求的目标。为了让机器具有感知和思考的能力&#xff0c;研究人员进行了一系列相关研究&#xff0c;如人脸识别、阅读理解和人机对话&…

LeetCode 1233. 删除子文件夹

1. 题目 你是一位系统管理员&#xff0c;手里有一份文件夹列表 folder&#xff0c;你的任务是要删除该列表中的所有 子文件夹&#xff0c;并以 任意顺序 返回剩下的文件夹。 我们这样定义「子文件夹」&#xff1a; 如果文件夹 folder[i] 位于另一个文件夹 folder[j] 下&…