田忌赛马(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;
    }

};

总结

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

相关推荐
只吹45°风2 分钟前
Java-ArrayList和LinkedList区别
java·arraylist·linkedlist·区别
覆水难收呀5 分钟前
三、(JS)JS中常见的表单事件
开发语言·前端·javascript
阿华的代码王国9 分钟前
【JavaEE】多线程编程引入——认识Thread类
java·开发语言·数据结构·mysql·java-ee
黑蛋同志9 分钟前
array和linked list的区别
java
繁依Fanyi15 分钟前
828 华为云征文|华为 Flexus 云服务器部署 RustDesk Server,打造自己的远程桌面服务器
运维·服务器·开发语言·人工智能·pytorch·华为·华为云
andrew_121915 分钟前
腾讯 IEG 游戏前沿技术 一面复盘
java·redis·sql·面试
寻求出路的程序媛23 分钟前
JVM —— 类加载器的分类,双亲委派机制
java·jvm·面试
这孩子叫逆25 分钟前
35. MyBatis中的缓存失效机制是如何工作的?
java·spring·mybatis
骆晨学长26 分钟前
基于SpringBoot的校园失物招领系统
java·spring boot
汇匠源26 分钟前
零工市场小程序:保障灵活就业
java·小程序·零工市场