田忌赛马(C++)

文章目录


前言

一、2418. 按身高排序

2418. 按身高排序

在介绍田忌赛马这道题目之前,我们需要先对这个道题目进行一定的掌握。

我们解决这道题目有很多方法,我们这里仅仅介绍一种最常用的。

题目中我们并不想排序后改变原始位置,我们可以用下面方法:

🌟1.创建一个数组下标

🌟2.对数组下标通过重写比较方法进行重新排序

🌟根据重新排序后的结果,找到原数组的信息。

cpp 复制代码
class Solution {
public:
    vector<string> sortPeople(vector<string>& names, vector<int>& heights) 
    {
        //1.创建一个数组下标
        int n=heights.size();
        vector<int>index(n);
        for(int i=0;i<n;i++)
        {
            index[i]=i;
        }
        //2.对数组下标进行排序,重写比较方法
        sort(index.begin(),index.end(),[&](int i,int j)
        {
            //按照身高降序排列
            return heights[i]>heights[j];
        });
        //3.根据数组下标排序后结果,找到原数组信息
        vector<string>ret;
        for(auto&e:index)
        {
            ret.push_back(names[e]);
        }
        
        return ret;
    }
};

二、870. 优势洗牌

870. 优势洗牌

算法原理

⽥忌赛⻢没听过的⾃⾏百度,这⾥讲⼀下⽥忌赛⻢背后的博弈决策,从三匹⻢拓展到 n 匹⻢之间

博弈的最优策略。

⽥忌:下等⻢ 中等⻢ 上等⻢

⻬王:下等⻢ 中等⻢ 上等⻢

比特就业课

a. ⽥忌的下等⻢ pk 不过⻬王的下等⻢,因此把这匹⻢丢去消耗⼀个⻬王的最强战⻢!

b. 接下来选择中等⻢ pk ⻬王的下等⻢,勉强获胜;

c. 最后⽤上等⻢ pk ⻬王的中等⻢,勉强获胜。

我们的策略:

🌟 先把两个数组进行升序排列

🌟 两个数组的最小值依次比较,如果nums1的最小值比nums2的最小值还小或者两个相等,我们就用他拼掉nums2中的最大值,获得利益最大化。

🌟 如果num1的最小值比nums2最小值大,就跟这个值比较,肯定能获胜

🌟 由于我们需要返回优势最大的数组,所以nums2的顺序不能动,但是我们又想用这个进行排序,就需要用到我们上面的方法了。

代码编写

cpp 复制代码
class Solution {
public:
    vector<int> advantageCount(vector<int>& nums1, vector<int>& nums2) 
    {
        //排序
        int n=nums1.size();
        sort(nums1.begin(),nums1.end());
        vector<int>index(n);
        for(int i=0;i<n;i++) index[i]=i;
        sort(index.begin(),index.end(),[&](int i,int j)
        {
            return nums2[i]<nums2[j];
        });

        //田忌赛马
        vector<int>ret(n);
        int left=0;
        int right=n-1;
        for(auto&e:nums1)
        {
            if(e<=nums2[index[left]]) ret[index[right--]]=e;
            else ret[index[left++]]=e;
        }

        return ret;
    }

};

总结

以上就是今天要讲的内容,本文仅仅详细介绍了 。希望对大家的学习有所帮助,仅供参考 如有错误请大佬指点我会尽快去改正 欢迎大家来评论~~ 😘 😘 😘

相关推荐
我的offer在哪里1 分钟前
Go语言内存管理与垃圾回收:低延迟、高吞吐的设计艺术
开发语言·golang·深度优先
掘根2 分钟前
【C++STL】list用法详解
开发语言·c++·list
似霰4 分钟前
Android Java Looper 机制
android·java·looper
JustMove0n4 分钟前
互联网大厂Java面试:从缓存到微服务的深度剖析
java·redis·spring cloud·微服务·大厂面试·互联网面试·监控与日志
BackCatK Chen4 分钟前
#基于C#的Socket多客户端通信系统
开发语言·网络协议·c#·socket·通信系统·多客户端·局域网协作
独好紫罗兰5 分钟前
对python的再认识-基于数据结构进行-a008-集合-拓展
开发语言·数据结构·python
羑悻的小杀马特6 分钟前
RabbitMQ如何成为分布式系统的“神经中枢“?——从安装部署到C++调用实战的完整流程,带你体验它的奥妙所在!
c++·分布式·消息队列·rabbitmq
Seven977 分钟前
剑指offer-74、n个骰⼦的点数
java
步步为营DotNet1 小时前
深度解析CancellationToken:.NET中的优雅取消机制
java·前端·.net
linweidong4 小时前
C++ 模块化编程(Modules)在大规模系统中的实践难点?
linux·前端·c++