LeetCode_56---Merge Intervals

本文深入探讨了使用Java集合类合并区间数组的算法,详细介绍了三种优化方法,包括原始方法、排序后合并和高效排序后的合并算法,并通过实例代码展示了算法的实现过程。

Given a collection of intervals, merge all overlapping intervals.

For example,
Given [1,3],[2,6],[8,10],[15,18],
return [1,6],[8,10],[15,18].

Hide Tags
  Array Sort

Code:


/**
 * 
 */
package From41;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.LinkedList;
import java.util.List;

/**
 * @author MohnSnow
 * @time 2015年6月26日 下午2:38:46
 * 
 */
public class LeetCode56 {

	/**
	 * @param argsmengdx
	 *            -fnst
	 */
	public static class Interval {
		int	start;
		int	end;

		Interval() {
			start = 0;
			end = 0;
		}

		Interval(int s, int e) {
			start = s;
			end = e;
		}

		public String toString() {
			String result = "start:" + start + " end: " + end;
			return result;
		}
	}

	// Time Limit Exceeded
	public static List<Interval> merge(List<Interval> intervals) {
		Interval temp;
		List<Interval> result = new LinkedList<Interval>();
		if (intervals.size() <= 1) {
			return intervals;
		}
		for (int i = intervals.size() - 1; i > 0; i--) {//复杂度太高
			for (int j = 0; j < i; j++) {
				if (intervals.get(i).start < intervals.get(j).start) {
					int tempInt = intervals.get(i).start;
					intervals.get(i).start = intervals.get(j).start;
					intervals.get(j).start = tempInt;
					tempInt = intervals.get(i).end;
					intervals.get(i).end = intervals.get(j).end;
					intervals.get(j).end = tempInt;
				}
			}
		}
		temp = new Interval(intervals.get(0).start, intervals.get(0).end);
		for (int i = 1; i < intervals.size(); i++) {
			if (temp.end >= intervals.get(i).start && temp.end < intervals.get(i).end) {
				temp.end = intervals.get(i).end;
			}
			if (temp.end < intervals.get(i).start) {
				result.add(temp);
				temp.start = intervals.get(i).start;//出错地方,这个地方我就先不改了
				temp.end = intervals.get(i).end;//出错地方,这个地方我就先不改了,造成了intervals里面的变化
			}
		}
		result.add(temp);
		return result;
	}

	//440msAC
	public static List<Interval> merge1(List<Interval> intervals) {
		List<Interval> result = new ArrayList<Interval>();
		if (intervals.size() <= 1) {
			return intervals;
		}
		Collections.sort(intervals, new Comparator<Interval>() {//借鉴下面方式
					@Override
					public int compare(Interval obj0, Interval obj1) {
						return obj0.start - obj1.start;
					}
				});
		Interval temp = null;
		for (int i = 0; i < intervals.size(); i++) {
			if (temp == null || temp.end < intervals.get(i).start) {
				result.add(intervals.get(i));
				temp = intervals.get(i);
			} else if (temp.end >= intervals.get(i).start && temp.end < intervals.get(i).end) {
				temp.end = intervals.get(i).end;
			}
		}
		return result;
	}

	//https://leetcode.com/discuss/33434/a-clean-java-solution
	//提供了一种排序方式
	public static List<Interval> merge2(List<Interval> intervals) {
		Collections.sort(intervals, new Comparator<Interval>() {
			@Override
			public int compare(Interval obj0, Interval obj1) {
				return obj0.start - obj1.start;
			}
		});

		List<Interval> ret = new ArrayList<>();
		Interval prev = null;
		for (Interval inter : intervals) {
			if (prev == null || inter.start > prev.end) {
				ret.add(inter);
				prev = inter;
			} else if (inter.end > prev.end) {
				// Modify the element already in list
				prev.end = inter.end;
			}
		}
		return ret;
	}

	public static void main(String[] args) {
		Interval a = new Interval(1, 4);
		Interval b = new Interval(5, 6);
		//Interval c = new Interval(9, 19);
		//Interval d = new Interval(15, 18);
		List<Interval> intervals = new LinkedList<Interval>();
		intervals.add(a);
		intervals.add(b);
		//intervals.add(c);
		//intervals.add(d);

		System.out.println("merge: " + merge(intervals));
		System.out.println("merge1: " + merge1(intervals));
		System.out.println("merge2: " + merge2(intervals));
	}

}



``` class Solution { public: vector<vector<int>> merge(vector<vector<int>>& intervals) { sort(intervals.begin(), intervals.end()); // 升序 vector<int> res; int n = intervals.size(); int start = intervals[0][0]; int end = intervals[0][1]; for (int i = 1; i < n; i++) { if (intervals[i][0] <= end) { // 重叠,合并 end = intervals[i][1]; } else { // 不重叠,加入结果数组 res.emplace_back(start, end); start = intervals[i][0]; end = intervals[i][1]; } } // 最后一个区间 res.emplace_back(start, end); return res; } };```In file included from prog_joined.cpp:1: In file included from ./precompiled/headers.h:25: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/ccomplex:39: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/complex:45: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/sstream:40: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/istream:40: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/ios:44: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/bits/ios_base.h:41: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/bits/locale_classes.h:40: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/string:54: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/bits/basic_string.h:39: In file included from /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/ext/alloc_traits.h:34: /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/bits/alloc_traits.h:536:4: error: no matching function for call to 'construct_at' 527 | std::construct_at(__p, std::forward<_Args>(__args)...); | ^~~~~~~~~~~~~~~~~ /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/bits/vector.tcc:117:21: note: in instantiation of function template specialization 'std::allocator_traits<std::allocator<int>>::construct<int, int &, int &>' requested here 108 | _Alloc_traits::construct(this->_M_impl, this->_M_impl._M_finish, | ^ Line 15: Char 21: note: in instantiation of function template specialization 'std::vector<int>::emplace_back<int &, int &>' requested here 15 | res.emplace_back(start, end); | ^ /usr/lib/gcc/x86_64-linux-gnu/14/../../../../include/c++/14/bits/stl_construct.h:94:5: note: candidate template ignored: substitution failure [with _Tp = int, _Args = <int &, int &>]: excess elements in scalar initializer 85 | construct_at(_Tp* __location, _Args&&... __args) | ^ 86 | noexcept(noexcept(::new((void*)0) _Tp(std::declval<_Args>()...))) 87 | -> decltype(::new((void*)0) _Tp(std::declval<_Args>()...)) | ~~~
最新发布
04-06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值