LeetCode57——Insert Interval

本文介绍了解决LeetCode57题的方法,该题涉及在已排序的区间序列中插入新区间并进行合并操作。通过实现类Solution,展示了如何在插入新区间后对整个序列进行有效合并。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

LeetCode57——Insert Interval

跟上一题LeetCode56——Merge Interval 类似。

这里我们先插入新的元素再对新的序列进行合并操作。

代码:

class Solution {
private:
	bool canMerge(Interval &a, Interval &b)
	{
		if (a.end >= b.start&&a.end <= b.end)
		{
			a.end = b.end;
			return true;
		}
		else if (a.end > b.end)
		{
			return true;
		}
		return false;
	}
public:
	vector<Interval> insert(vector<Interval>& intervals, Interval newInterval) {
		vector<Interval>result;
		int index = 0;
		while (index<intervals.size()&&intervals[index].start < newInterval.start)
			index++;//插入位置的索引
		intervals.insert(intervals.begin() + index, newInterval);
		int i = 0;
		int j;
		while (i < intervals.size())
		{
			j = i + 1;
			while (j<intervals.size() && canMerge(intervals[i], intervals[j]))
				j++;
			result.push_back(intervals[i]);
			i = j;
		}
		return result;
	}
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值