题解 | #合并区间#

合并区间

https://www.nowcoder.com/practice/69f4e5b7ad284a478777cb2a17fb5e6a

package main

//先做排序然后再一个个区间进行合并
import . "nc_tools"
import "sort"

/*
 * type Interval struct {
 *   Start int
 *   End int
 * }
 */

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param intervals Interval类一维数组
 * @return Interval类一维数组
 */


type SortInterval []*Interval

func (s SortInterval) Len() int {
	return len(s)
}

func (s SortInterval) Less(i, j int) bool {
	if s[i].Start < s[j].Start {
		return true
	}
	if s[i].Start == s[j].Start {
		return s[i].End < s[j].End
	}
	return false
}

func (s SortInterval) Swap(i, j int) {
	s[i], s[j] = s[j], s[i]
}

func merge(intervals []*Interval) []*Interval {
	// write code here
    if len(intervals) == 0 {
		return intervals
	}
	//排序好
	sort.Sort(SortInterval(intervals))

	//合并区间
	res := make([]*Interval, 0)
	curIv := intervals[0]
	for i := 1; i < len(intervals); i++ {
		tmpIv := intervals[i]
		if tmpIv.Start > curIv.End {
			res = append(res, curIv)
			curIv = tmpIv
			continue
		}
		//可能存在交叉;进行合并
		tmpStart := curIv.Start
		if tmpIv.Start < tmpStart {
			tmpStart = tmpIv.Start
		}
		tmpEnd := curIv.End
		if tmpIv.End > tmpEnd {
			tmpEnd = tmpIv.End
		}
		curIv.Start = tmpStart
		curIv.End = tmpEnd
	}
    	res = append(res,curIv)
	return res
}

全部评论

相关推荐

offer多多的六边形战士很无语:看了你的博客,感觉挺不错的,可以把你的访问量和粉丝数在简历里提一下,闪光点(仅个人意见)
点赞 评论 收藏
分享
10-24 11:10
山西大学 Java
若梦难了:哥们,面试挂是很正常的。我大中厂终面挂,加起来快10次了,继续努力吧。
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务