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

会员充值网站怎么做在线友情链接

会员充值网站怎么做,在线友情链接,统计局网站建设,eclipse做企业网站目录 LeeCode 435. 无重叠区间 LeeCode 763.划分字母区间 LeeCode 56. 合并区间 LeeCode 435. 无重叠区间 435. 无重叠区间 - 力扣(LeetCode) 思路1:按照右边界排序,从左向右记录非交叉区间的个数。最后用区间总数减去非交叉…

目录

LeeCode 435. 无重叠区间

LeeCode 763.划分字母区间

LeeCode 56. 合并区间


LeeCode 435. 无重叠区间

435. 无重叠区间 - 力扣(LeetCode)

思路1:按照右边界排序,从左向右记录非交叉区间的个数。最后用区间总数减去非交叉区间的个数就是需要移除的区间个数了。

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

class Solution {
public:static bool cmp (const vector<int>& a, const vector<int>& b) {return a[1] < b[1];}int eraseOverlapIntervals(vector<vector<int>>& intervals) {if (intervals.size() == 0) return 0;sort(intervals.begin(), intervals.end(), cmp);int count = 1;int end = intervals[0][1];for (int i = 1; i < intervals.size(); i++) {if (end <= intervals[i][0]) {end = intervals[i][1];count++;}}return intervals.size() - count;}
};

思路2:左边界排序,直接求 重叠的区间,count记录重叠区间数。

class Solution {
public:static bool cmp (const vector<int>& a, const vector<int>& b) {return a[0] < b[0];}int eraseOverlapIntervals(vector<vector<int>>& intervals) {if (intervals.size() == 0) return 0;sort(intervals.begin(), intervals.end(), cmp);int count = 0;for (int i = 1; i < intervals.size(); i++) {if (intervals[i][0] < intervals[i - 1][1]) {intervals[i][1] = min(intervals[i - 1][1], intervals[i][1]);count++;}}return count;}
};

LeeCode 763.划分字母区间

763. 划分字母区间 - 力扣(LeetCode)

思路1:遍历的过程中找每一个字母的边界,如果找到之前遍历过的所有字母的最远边界,说明这个边界就是分割点。

class Solution {
public:vector<int> partitionLabels(string s) {int hash[27] = {0};for (int i = 0; i < s.size(); i++) {hash[s[i] - 'a'] = i;}vector<int> result;int left = 0, right = 0;for (int i = 0; i < s.size(); i++) {right = max(right, hash[s[i] - 'a']);if (i == right) {result.push_back(right - left + 1);left = i + 1;}}return result;}
};

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

class Solution {
public:static bool cmp(vector<int>& a, vector<int>& b) {return a[0] < b[0];}vector<vector<int>> countLabels(string s) {vector<vector<int>> hash(26, vector<int>(2,INT_MIN));vector<vector<int>> hash_filter;for (int i = 0; i < s.size(); i++) {if (hash[s[i] - 'a'][0] == INT_MIN)  hash[s[i] - 'a'][0] = i;hash[s[i] - 'a'][1] = i;}for (int i = 0; i < hash.size(); i++) {if (hash[i][0] != INT_MIN)  hash_filter.push_back(hash[i]);}return hash_filter;}vector<int> partitionLabels(string s) {vector<int> res;vector<vector<int>> hash = countLabels(s);sort(hash.begin(), hash.end(), cmp);int rightBoard = hash[0][1];int leftBoard = 0;for (int i = 1; i < hash.size(); i++) {if (hash[i][0] > rightBoard) {res.push_back(rightBoard - leftBoard + 1);leftBoard = hash[i][0];}rightBoard = max(rightBoard, hash[i][1]);} res.push_back(rightBoard - leftBoard + 1);return res;}
};

LeeCode 56. 合并区间

56. 合并区间 - 力扣(LeetCode)

思路:对区间排序后判断是否重合,合并区间:将合并后的左右边界,作为一个新的区间,加入到result数组里就可以了。如果没有合并就把原区间加入到result数组。

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

class Solution {
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {vector<vector<int>> result;if (intervals.size() == 0) return result;sort(intervals.begin(), intervals.end(), [](const vector<int>& a, const vector<int>& b){return a[0] < b[0];});result.push_back(intervals[0]);for (int i = 1; i < intervals.size(); i++) {if (result.back()[1] >= intervals[i][0]) result.back()[1] = max(result.back()[1], intervals[i][1]);else result.push_back(intervals[i]);}return result;}
};
http://www.zhongyajixie.com/news/12016.html

相关文章:

  • 转 如何用java做网站抖音指数查询
  • 买了服务器不翻墙就用来 做网站宁波正规seo推广
  • 深圳电商网站设计公司建立网站
  • 全自动挂机赚钱一天40元seo大全
  • 义乌网站建设zisou8谷歌seo综合查询
  • 动漫画设计与制作是学什么西安seo关键词查询
  • 义乌门户网站建设互联网怎么打广告推广
  • 海口网站建设58同城推广
  • 清理wordpress模板百度搜索引擎优化公司哪家强
  • 自己做网站怎么上传到网上360搜索引擎优化
  • 做网站要用服务器维护百度引流推广怎么收费
  • 公司的官方网站怎么做平台运营推广方案
  • 室内设计周报seo助力网站转化率提升
  • 浅谈中兴电子商务网站建设旺道网站优化
  • 海南省住房公积金管理局网站蚌埠seo外包
  • 阿里云服务器可以做商业网站最常用的几个关键词
  • 微信服务号菜单链接网站怎么做seo站长常用工具
  • 做软件多少钱seo1短视频网页入口营销
  • 深圳住房和建设局网站公开招标win7一键优化工具
  • ps网页版在线使用最全版台州关键词首页优化
  • 在哪些网站做兼职比较可靠网上电商怎么做
  • 重庆天古装饰公司百度seo公司整站优化
  • 简述营销型网站开发流程seo站长工具是什么
  • 服装型网站开发app拉新推广平台有哪些
  • 个人网站模板 php贵阳网站建设公司
  • 廊坊企业做网站北京百度推广投诉电话
  • 建设网站采用的网络技术软文代写发布网络
  • 阿里云网站建设考试题目个人开发app可以上架吗
  • wordpress影院插件seo怎么做优化工作
  • 淘宝网站怎么做特价零基础seo入门教学