【代码随想录二刷】Day36-贪心-Go

代码随想录二刷Day36

今日任务

435.无重叠区间
763.划分字母区间
56.合并区间
语言:Go

435. 无重叠区间

链接:https://leetcode.cn/problems/non-overlapping-intervals/

func min(i, j int) int {
    if i < j {
        return i
    } else {
        return j
    }
}

func eraseOverlapIntervals(intervals [][]int) int {
	//按区间左边界排序,也可按照区间右边界排序,就是要减一下
    sort.Slice(intervals, func(i, j int) bool {
        return intervals[i][0] < intervals[j][0]
    })
    count := 0
    for i := 0; i < len(intervals) - 1; i++ {
        if intervals[i][1] > intervals[i + 1][0] {
            intervals[i + 1][1] = min(intervals[i][1], intervals[i + 1][1])
            count++
        }
    }
    return count
}

763. 划分字母区间

链接:https://leetcode.cn/problems/partition-labels/

func partitionLabels(s string) []int {
    temp := make([]int, len(s))
    count := 0
    record := make([]int, 26)
    for i := 0; i < len(s); i++ {
        record[s[i] - 'a'] = i
    }
    left := 0
    right := record[s[0] - 'a']
    for i := 0; i < len(s); i++ {
        nextPos := record[s[i] - 'a']
        if i <= nextPos && nextPos > right {
            right = nextPos
        } else if i == right {
            temp[count] = right - left + 1
            count++
            left = i + 1
            right = i + 1
        }
    }
    res := make([]int, count)
    for i := 0; i < count; i++ {
        res[i] = temp[i]
    }
    return res
}

用append

func partitionLabels(s string) []int {
    var res []int
    record := make([]int, 26)
    for i := 0; i < len(s); i++ {
        record[s[i] - 'a'] = i
    }
    left := 0
    right := record[s[0] - 'a']
    for i := 0; i < len(s); i++ {
        nextPos := record[s[i] - 'a']
        if i <= nextPos && nextPos > right {
            right = nextPos
        } else if i == right {
            res = append(res, right - left + 1)
            left = i + 1
            right = i + 1
        }
    }
    return res
}

56. 合并区间

链接:https://leetcode.cn/problems/merge-intervals/

func max(i, j int) int {
    if i < j {
        return j
    } else {
        return i
    }
}

func merge(intervals [][]int) [][]int {
    sort.Slice(intervals, func(i, j int) bool {
        return intervals[i][0] < intervals[j][0]
    })
    var res [][]int
    left, right := intervals[0][0], intervals[0][1]
    for i := 1; i < len(intervals); i++ {
        if intervals[i][0] <= right {
            right = max(intervals[i][1], right)
        } else {
            res = append(res, []int{left, right})
            left = intervals[i][0]
            right = intervals[i][1]
        }
    }
    res = append(res, []int{left, right})
    return res
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值