📝前言说明:

  • 本专栏主要记录本人的贪心算法学习以及LeetCode刷题记录,按专题划分
  • 每题主要记录:(1)本人解法 + 本人屎山代码;(2)优质解法 + 优质代码;(3)精益求精,更好的解法和独特的思想(如果有的话);(4)贪心策略正确性的 “证明”
  • 文章中的理解仅为个人理解。如有错误,感谢纠错

🎬个人简介:努力学习ing
📋本专栏:C++刷题专栏
📋其他专栏:C语言入门基础,python入门基础,C++学习笔记,Linux
🎀CSDN主页 愚润泽

你可以点击下方链接,进行其他贪心算法题目的学习

点击链接开始学习
贪心day1贪心day2
贪心day3贪心day4
贪心day5贪心day6
贪心day7贪心day8
贪心day9贪心day10

也可以点击下面连接,学习其他算法

点击链接开始学习
优选专题动态规划
递归、搜索与回溯贪心算法

题目

  • 870. 优势洗牌
    • 优质解
  • 409. 最长回文串
    • 个人解
  • 942. 增减字符串匹配
    • 个人解


870. 优势洗牌

题目链接:https://leetcode.cn/problems/advantage-shuffle/description/
在这里插入图片描述


优质解

思路:

  • 田忌赛马的策略
    • 用最弱的马(如果这个马一个都比不过)消耗对手最强的马
    • 每次战胜对面马的时候,保留更强的马
  • 实现方法:我们可以将两个数组都排序,然后从小到大遍历,依次填写答案
  • 细节:因为数组是被排序后的,所以我们得到的答案不是针对原数组的顺序来排序的
    • 解决方法:如果我们 即想对数组排序 + 保留原来数组的顺序信息 → 直接排序下标数组

代码:

class Solution {
public:vector<int> advantageCount(vector<int>& nums1, vector<int>& nums2) {int n = nums1.size();vector<int> indexs(n);for(int i = 0; i < n; i++) indexs[i] = i; // 下标数组// 排序ranges::sort(indexs.begin(), indexs.end(), [&](const int& a, const int& b){return nums2[a] < nums2[b];});ranges::sort(nums1); // 贪心vector<int> ans(n);int right = n - 1, left = 0; // 代表 nums2 当前的最大数和最小数的"下标位置"for(int i = 0; i < n; i++) // 遍历 num1 重新排序{// 如果小的比不过,用它去消耗nums2的最大数if(nums1[i] <= nums2[indexs[left]]) // indexs[i] 获取该位置元素在原数组的原始下标ans[indexs[right--]] = nums1[i];elseans[indexs[left++]] = nums1[i]; // 战胜当前的,进行下一个比较}return ans;}
};

时间复杂度:O(nlogn)O(nlogn)O(nlogn)
空间复杂度:O(n)O(n)O(n)


409. 最长回文串

题目链接:https://leetcode.cn/problems/longest-palindrome/description/
在这里插入图片描述

个人解

屎山代码:

class Solution {
public:int longestPalindrome(string s) {int ans = 0;int flag = 0; // 判断是否有单数的字符的,如果有的话,把多出的单个字符放在中间位置(有且仅有一个可放)unordered_map<char, int> hash; // 分别统计每个字符出现的次数for(auto ch: s)hash[ch]++;for(auto [ch, count]: hash){if(count % 2 && !flag) // 放中间位置{ans++;flag = 1;}ans += 2 * (count / 2);}return ans;}
};

时间复杂度:O(n)O(n)O(n)
空间复杂度:O(n)O(n)O(n)


942. 增减字符串匹配

题目链接:https://leetcode.cn/problems/di-string-match/description/
在这里插入图片描述

个人解

思路:

  • 从左往右放
  • 遇到 I 的时候,放最小的数字 -> 右边的(大数)选择更多
  • 遇到 D 的时候,放最大的数字 -> 右边的(小数)选择更多

屎山代码:

class Solution {
public:vector<int> diStringMatch(string s) {int left = 0, right = s.size();vector<int> ans;for(auto ch: s){if(ch == 'I')ans.push_back(left++);elseans.push_back(right--);}ans.push_back(left); // 放入第 n + 1 个数(前面的数都是按规则排好的,最后一个直接放就行)return ans;}
};

时间复杂度:O(n)O(n)O(n)
空间复杂度:O(n)O(n)O(n)


🌈我的分享也就到此结束啦🌈
要是我的分享也能对你的学习起到帮助,那简直是太酷啦!
若有不足,还请大家多多指正,我们一起学习交流!
📢公主,王子:点赞👍→收藏⭐→关注🔍
感谢大家的观看和支持!祝大家都能得偿所愿,天天开心!!!

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

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

相关文章

软考中级【网络工程师】第6版教材 第4章 无线通信网 (上)

考点分析: 重要程度:⭐⭐⭐ 选择题考查1 ~ 3分,案例分析可能考查填空和简答 高频考点:802.11信道与频段、CSMA/CA、无线网络优化、无线认证、无线配置步骤 新教材变化:新增4G/5G、删除无线城域网 本章将详述蜂窝移动通信系统、无线局域网以及无线个人网的体系结构和实用技…

vscode+EIDE+Clangd环境导入keil C51以及MDK工程

我最近一直在使用vscodeclangd的编译环境替代了vscode自带的c/c插件。感觉clangd的环境更加优秀&#xff0c;能够更好找到函数、全局变量等定义调用等。如果使用keil C51以及MDK环境开发51单片机或者STM32单片机就需要使用到了EIDE这个插件这个插件现在能够自动生成compile_com…

FTP - 学习/实践

1.应用场景 主要用于学习和使用FTP服务&#xff0c;同时研究其架构实现, 以及日常开发中的使用。 FTP&#xff08;文件传输协议&#xff09;是一种用于网络文件传输的标准协议&#xff0c;基于客户端-服务器模型运行&#xff0c;通过控制通道&#xff08;端口21&#xff09;和…

【瑞吉外卖】手机号验证码登录(用QQ邮件发送代替)

目录 介绍 一、获取授权码 二、前端代码修改 三、后端代码修改 ①pom依赖 ②yml配置 ③控制层 ④业务层 ⑤工具类 介绍 本文介绍了QQ邮箱验证码登录功能的实现步骤&#xff1a; 获取QQ邮箱授权码并配置&#xff1b;前端修改登录页面&#xff0c;增加验证码发送接口调…

为什么要用 Markdown?以及如何使用它

在处理大量文档时&#xff0c;尤其是在构建知识库、进行文档分析或训练大语言模型&#xff08;LLM&#xff09;时&#xff0c;将各种格式的文件&#xff08;如 PDF、Word、Excel、PPT、HTML 等&#xff09;转换为统一的 Markdown 格式&#xff0c;能够显著提高处理效率和兼容性…

订餐后台管理系统-day06菜品分类模块

菜品分类显示我们需要先实现分类操作&#xff0c;因为没有菜品分类&#xff0c;我们无法准确知道当前菜品属于哪个分类&#xff0c;在前端显示时&#xff0c;需要根据分类显示数据先显示分类列表页面准备路由manage_bp.route(/food/cat/list) def food_cat_list():# 默认页面从…

More Effective C++ 条款20:协助完成返回值优化(Facilitate the Return Value Optimization)

More Effective C 条款20&#xff1a;协助完成返回值优化&#xff08;Facilitate the Return Value Optimization&#xff09;核心思想&#xff1a;返回值优化&#xff08;RVO&#xff09;是编译器消除函数返回时临时对象的一种重要优化技术。通过编写适合RVO的代码&#xff0c…

《HelloGitHub》第 113 期

兴趣是最好的老师&#xff0c;HelloGitHub 让你对开源感兴趣&#xff01;简介HelloGitHub 分享 GitHub 上有趣、入门级的开源项目。github.com/521xueweihan/HelloGitHub这里有实战项目、入门教程、黑科技、开源书籍、大厂开源项目等&#xff0c;涵盖多种编程语言 Python、Java…

萌宝喂养日志-我用AI做喂养记录小程序1-原型设计

准备工作 首先&#xff0c;注册硅基流动账号&#xff0c;并配置Trae开发工具。 ↓现在注册有2000 万 Tokens 的免费额度↓。 硅基流动统一登录 具体可以看我这篇文章&#xff1a;Trae接入自有Deepseek模型&#xff0c;不再排队等待-CSDN博客 实践 设计原型图 我想开发一…

工业产品营销:概念、原理、流程与实践指南

摘要 工业产品营销是针对B2B市场的专业化推广活动,旨在满足企业客户的生产和运营需求。本文详细阐述了工业产品营销的概念与特点,分析其核心原理,包括客户需求驱动、价值传递和关系管理。营销过程涵盖市场调研、细分定位、策略制定、执行、转化及售后服务六个步骤,并提供品…

【读书笔记】《人体微生物的奥秘》

Follow Your Gut&#xff1a;人体微生物的奥秘 引言&#xff1a;从蚊子到微生物 夏天来临&#xff0c;许多人又开始纠结为什么有些人特别招蚊子。有人说是血型问题&#xff0c;有人说是皮肤嫩度&#xff0c;还有人归结于基因。但今天要分享的一本书&#xff0c;虽然标题看似讨论…

【Matplotlib学习】驾驭画布:Matplotlib 布局方式从入门到精通完全指南

目录驾驭画布&#xff1a;Matplotlib 布局方式从入门到精通完全指南一、 核心理念&#xff1a;理解 Figure 和 Axes二、 布局方式大全&#xff1a;从简单到复杂类别一&#xff1a;自动创建与基础单图布局类别二&#xff1a;规律网格布局 - 主力军类别三&#xff1a;复杂网格布局…

【C#】在一个任意旋转的矩形(由四个顶点定义)内绘制一个内切椭圆

核心点&#xff1a;在一个任意旋转的矩形&#xff08;由四个顶点定义&#xff09;内绘制一个内切椭圆 实现步骤 计算矩形中心&#xff1a;作为旋转中心点 创建椭圆路径&#xff1a;在未旋转状态下定义椭圆 应用旋转变换&#xff1a;使用矩阵绕中心点旋转路径 绘制变换后的路…

洛谷 P2052 [NOI2011] 道路修建-普及/提高-

P2052 [NOI2011] 道路修建 题目描述 在 W 星球上有 nnn 个国家。为了各自国家的经济发展&#xff0c;他们决定在各个国家之间建设双向道路使得国家之间连通。但是每个国家的国王都很吝啬&#xff0c;他们只愿意修建恰好 n−1n - 1n−1 条双向道路。 每条道路的修建都要付出一定…

springboot连接不上redis,但是redis客户端是能连接上的

除了常规排查&#xff0c;还有一个就是检查配置文件格式。这个旧版本格式会导致读取不到配置&#xff0c;spring:# 对应 RedisProperties 类redis:host: 127.0.0.1port: 6379 # password: 123456 # Redis 服务器密码&#xff0c;默认为空。生产中&#xff0c;一定要设置 Red…

GitBook 完整使用指南:从安装到部署

文章目录 环境准备 Node.js 安装 GitBook CLI 安装 项目初始化 创建项目结构 (可选) npm 初始化 目录结构配置 开发与调试 本地服务启动 构建静态文件 配置文件详解 插件系统 常用插件推荐 插件安装与配置 自定义样式 部署指南 GitHub Pages 部署 Netlify 部署 高级功能 多语言…

VS安装 .NETFramework,Version=v4.6.x

一、前言 在使用VS2019打开项目时提示MSB3644 找不到 .NETFramework,Versionv4.6.2 的引用程序集的错误 二、解决方案 1.百度......找到了解决方法了 2.打开Visual Studio Install 3.点击修改 4.点击单个组件&#xff0c;安装相对应的版本即可

Visual Studio Code中launch.json的解析笔记

<摘要> launch.json 是 Visual Studio Code 中用于配置调试任务的核心文件。本文解析了其最常用的配置字段&#xff0c;涵盖了基本调试设置、程序控制、环境配置和高级调试功能。理解这些字段能帮助开发者高效配置调试环境&#xff0c;提升开发效率。<解析> 1. 背景…

试试 Xget 加速 GitHub 克隆仓库

引言 在全球化软件开发环境中&#xff0c;开发者经常面临跨地域访问GitHub等平台的网络挑战&#xff1a;下载速度缓慢、连接不稳定、甚至完全无法访问。这些问题严重影响了开发效率和协作体验。Xget作为一个开源的高性能资源获取加速引擎&#xff0c;通过智能路由、多节点分发…

优雅处理Go中的SIGTERM信

在Go语言中优雅处理SIGTERM信号需通过os/signal包实现&#xff0c;核心流程包括信号注册、异步监听和资源清理。SIGTERM 是一种常见的进程终止信号&#xff0c;它允许程序在退出前执行必要的清理操作。与之不同&#xff0c;SIGKILL 信号无法被进程捕获或忽略。未处理的 SIGTERM…