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

};

总结

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

相关推荐
exe4528 分钟前
力扣每日一题5-19
java·算法·leetcode
冷yan~10 分钟前
构建下一代AI智能体:基于Spring AI的多轮对话应用
java·人工智能·spring·ai
?abc!11 分钟前
spring框架中的本地缓存:spring cache基本使用
java·spring·缓存
ABCDEEE715 分钟前
SpringAI
java
共享家952722 分钟前
布隆过滤器
c++
不穿铠甲的穿山甲39 分钟前
mysql-Java手写分布式事物提交流程
java·分布式·mysql
mochensage1 小时前
2025年全国青少年信息素养大赛C++小学全年级初赛试题
开发语言·c++·算法
胜玲龙1 小时前
单点登录是是什么?具体流程是什么?
java·服务器·前端
mxs05231 小时前
抢购Python代码示例与技术解析
开发语言·数据库·python
快乐肚皮1 小时前
基于Spring Cloud Sentinel自研Slot扩展实战
java·spring cloud·sentinel