代码随想录算法训练营第36期DAY38

DAY38

435无重叠区间

昨晚很快就想出来了,今天相当于二刷。

  1. class Solution {
  2. public:
  3.     static bool mycmp(vector<int>&a,vector<int>&b){
  4.         return a[1]<b[1];
  5.     }
  6.     int eraseOverlapIntervals(vector<vector<int>>& intervals) {
  7.         int res=0;
  8.         sort(intervals.begin(),intervals.end(),mycmp);
  9.         int end=intervals[0][1];
  10.         for(int i=1;i<intervals.size();i++){
  11.             if(intervals[i][0]<end){
  12.                 res++;
  13.                 continue;
  14.             }
  15.             end=intervals[i][1];
  16.         }
  17.         return res;
  18.     }
  19. };

763划分字母区间

  1. COZE的解法:记录每个元素的最终位置,如果当前遍历到了元素的最终位置,就将长度加入到结果集中。写得很巧妙,不容易想到:很多变量的使用技巧、算法设计。之后吸收其他优质题解,先自己按着算法思路写一遍:

动手模拟一遍,就掌握该算法了:

  1. class Solution {
  2. public:
  3.     vector<intpartitionLabels(string s) {
  4.         vector<int> res;
  5.         vector<intlast(26,0);
  6.         for(int i=0;i<s.size();i++){
  7.             last[s[i]-'a']=max(last[s[i]-'a'],i);
  8.         }
  9.         int j=0,anthor=0;
  10.         for(int i=0;i<s.size();i++){
  11.             j=max(j,last[s[i]-'a']);
  12.             if(i==j){
  13.                 res.push_back(j-anthor+1);
  14.                 anthor=i+1;
  15.             }
  16.         }
  17.         return res;
  18.     }
  19. };

  1. 力扣优质题解,3份,加深记忆

想切割,要有首尾两个指针,确定了结尾指针,就能确定下一个切割的开始指针。
遍历字符串,如果已扫描部分的所有字符,都只出现在已扫描的范围内,即可做切割。

出自力扣博主:笨猪爆破组(https://leetcode.cn/u/xiao_ben_zhu/)

力扣数学描述:出自力扣官方题解:(https://leetcode.cn/u/leetcode-solution/)

  1. 代码随想录题解

需要额外学习:与区间操作类似的解法:

统计字符串中所有字符的起始和结束位置,记录这些区间,将区间按左边界从小到大排序,找到边界将区间划分成组,互不重叠。找到的边界就是答案。

过了,二刷一下:

  1. class Solution {
  2. public:
  3.     static bool mycmp(vector<int>&a,vector<int>&b){
  4.         return a[0]<b[0];
  5.     }
  6.     vector<vector<int>> CountHash(string s){
  7.         vector<vector<int>> hash(26,vector<int>(2,INT_MIN));
  8.         vector<vector<int>> hashfilter;
  9.         for(int i=0;i<s.size();i++){
  10.             if(hash[s[i]-'a'][0]==INT_MIN) hash[s[i]-'a'][0]=i;
  11.             hash[s[i]-'a'][1]=i;
  12.         }
  13.         for(int i=0;i<hash.size();i++){
  14.             if(hash[i][0]!=INT_MIN) hashfilter.push_back(hash[i]);
  15.         }
  16.         return hashfilter;
  17.     }
  18.     vector<intpartitionLabels(string s) {
  19.         vector<int> res;
  20.         vector<vector<int>> tmp=CountHash(s);
  21.         sort(tmp.begin(),tmp.end(),mycmp);
  22.         int st=0,ed=tmp[0][1];
  23.         for(int i=1;i<tmp.size();i++)
  24.         {
  25.             if(tmp[i][0]>ed){
  26.                 res.push_back(ed-st+1);
  27.                 st=tmp[i][0];
  28.             }
  29.             ed=max(ed,tmp[i][1]);
  30.         }
  31.         res.push_back(ed-st+1);
  32.         return res;
  33.     }
  34. };

56合并区间

模版题,昨天正好复习了ACWING区间合并模版:

  1. class Solution {
  2. public:
  3.     static bool mycmp(vector<int>&a,vector<int>&b){
  4.         return a[0]<b[0];
  5.     }
  6.     vector<vector<int>> merge(vector<vector<int>>& intervals) {
  7.         vector<vector<int>> res;
  8.         int st=INT_MIN,ed=INT_MIN;
  9.         sort(intervals.begin(),intervals.end(),mycmp);
  10.         for(int i=0;i<intervals.size();i++){
  11.             //不重叠
  12.             if(ed<intervals[i][0]){
  13.                 if(ed!=INT_MIN) res.push_back({st,ed});
  14.                 st=intervals[i][0],ed=intervals[i][1];
  15.             }
  16.             //重叠  
  17.             else{
  18.                 ed=max(intervals[i][1],ed);
  19.             }
  20.         }
  21.         res.push_back({st,ed});
  22.         return res;
  23.     }
  24. };

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值