您的位置:首页 > 科技 > 能源 > qq浏览器在线网页_浙江正规网站建设配件_今日新闻摘抄50字_天津做网站的公司

qq浏览器在线网页_浙江正规网站建设配件_今日新闻摘抄50字_天津做网站的公司

2025/1/4 15:51:28 来源:https://blog.csdn.net/qq_74276498/article/details/144796336  浏览:    关键词:qq浏览器在线网页_浙江正规网站建设配件_今日新闻摘抄50字_天津做网站的公司
qq浏览器在线网页_浙江正规网站建设配件_今日新闻摘抄50字_天津做网站的公司

1. 主持人调度(一)

题目来源

class Solution {
public:bool hostschedule(vector<vector<int>>& schedule) {// write code heresort(schedule.begin(), schedule.end());int start = -1, end = 0;for (auto & nums : schedule){end = nums[0];if (end < start) return false;start = nums[1];}return true;}
};

2. 有效三角形的个数

题目来源
给定一个包含非负整数的数组 nums ,返回其中可以组成三角形三条边的三元组个数。
示例 1:

输入: nums = [2,2,3,4]
输出: 3
解释:有效的组合是:
2,3,4 (使用第一个 2)
2,3,4 (使用第二个 2)
2,2,3

  • 第一步:之类的方法就是先进行排序,先选定一个基准值,这里我们的起始基准值是最后一个也就是nums[nums.size() - 1]
  • 第二步:然后给定两个指针,一个指针从开头开始,另一个从基准值的前一个开始。
  • 第三步:根据三角形的定理,两边之和大于第三边,这里如果num[left] + nums[right] 的话就符合条件,那么也就是说从left到right之间的的数都是符合条件的,所以这里只需要right–即可,反之left++
class Solution {
public:int triangleNumber(vector<int>& nums) {// 先进行排序sort(nums.begin(), nums.end());int count = 0;for (int i = nums.size() - 1; i >= 0; i--){int left = 0, right = i - 1;while (left < right){if (nums[left] + nums[right] > nums[i]){count += right - left;right--;}else left++;}}return count;}
};

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com