当前位置: 首页 > news >正文

建网站如何备案江门做网站那家公司好

建网站如何备案,江门做网站那家公司好,银川网站开发,衡阳企业seo优化费用📝前言说明: 本专栏主要记录本人的贪心算法学习以及LeetCode刷题记录,按专题划分每题主要记录:(1)本人解法 本人屎山代码;(2)优质解法 优质代码;&#xff…

📝前言说明:

  • 本专栏主要记录本人的贪心算法学习以及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.dtcms.com/a/405617.html

相关文章:

  • 西部数码网站管理助手 伪静态centos一键wordpress
  • 新媒体 网站建设 影视wordpress 悬浮页
  • 中小企业做网站贷款家庭优化大师
  • 二级域名网站建设规范网站开发工程师优势
  • 政务移动门户网站建设方案网站后台更新没有变化
  • 可以用什么网站做mc官方seo扣费系统源码
  • 苏州做网站怎么样大型网站的制作
  • 网站广告推广哪家好黄骅港中远海运物流有限公司
  • 可以做软文的网站怎么制作代码
  • 做网站建设客户从哪里找wordpress突然打不开
  • 大型网站如何做别名网站系统报价方案模板下载
  • 界面十分好看的网站网站内页是什么
  • 外贸网站推广 sit网站建设 自己的服务器
  • 电商网站建设实训心得手绘元素素材
  • 建设网站联系方式百度网址大全旧版安装
  • 个人网站主页设计教程腾讯官网首页登录入口
  • 优质高等职业院校建设申报网站怎么制作游戏地图
  • 宁波建设银行管方网站网站用的服务器
  • 网站一般多长时间前端学校网站开发视频
  • 合肥网站定制建设公司官方网站首页
  • 昆山网站建设多少钱wordpress 多媒体文件夹
  • 网站建设 柳州手机上安装wordpress
  • 微信的微网站是什么海外域名提示风险网站吗
  • 电子商务网站建设教学加盟招商推广网站
  • 哪个网站可以做兼职讲师宣传册免费模板
  • 团队建设海报网站有网站源码怎么上传
  • 提高网站公信力 单仁建设工程协会网站查询系统
  • 深圳哪家网站建设服务好代账行业门户网站开发
  • 电竞竞猜网站 建设长沙装修公司招聘
  • 网站开发页面静态化技术营销型网站免费模板下载