美文网首页
2019-09-29

2019-09-29

作者: Jiawei_84a5 | 来源:发表于2019-09-29 18:53 被阅读0次

Course Schedule

func canFinish(numCourses int, prerequisites [][]int) bool {
    m := make(map[int][]int)
    res := make([]int, numCourses)
    for _, p := range prerequisites {
        v, ok := m[p[0]]
        if !ok {
            m[p[0]] = []int{p[1]}
        } else {
            m[p[0]] = append(v, p[1])
        }
    }
    for i := 0; i < numCourses; i++ {
        if helper(i, res, m) == false {
            return false
        }
    }
    return true
}
func helper(idx int, res []int, m map[int][]int) bool {
    if res[idx] == 1 {
        return true
    }
    if res[idx] == 2 {
        return false
    }
    v, ok := m[idx]
    if !ok {
        return true
    }
    res[idx] = 2
    for i := 0; i < len(v); i++ {
        if helper(v[i], res, m) == false {
            return false
        }
    }
    res[idx] = 1
    return true
}



Longest Repeating Character Replacement

func characterReplacement(s string, k int) int {
    if len(s) == 0 {
        return 0
    }
    str := []byte(s)
    start, end := 0, 0
    ret := 0
    c := make([]int, 26)
    c[str[0]-'A']++
    for len(str) > end {
        maxc := 0
        for i := 0; i < 26; i++ {
            if c[i] > maxc {
                maxc = c[i]
            }
        }
        if maxc+k > end-start {
            end++
            if end < len(str) {
                c[str[end]-'A']++
            }
        } else {
            c[str[start]-'A']--
            start++
        }
        if maxc+k > ret {
            if maxc+k <= len(str) {
                ret = maxc + k
            } else {
                ret = len(str)
            }
        }
    }
    return ret
}

Group Anagrams

type sortRunes []rune

func (s sortRunes) Less(i, j int) bool {
    return s[i] < s[j]
}

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

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

func SortString(s string) string {
    r := []rune(s)
    sort.Sort(sortRunes(r))
    return string(r)
}

func groupAnagrams(strs []string) [][]string {
    ret := [][]string{}
    dic := make(map[string]int, len(strs))
    idx := 0
    for _, str := range strs {
        tmp := SortString(str)
        val, ok := dic[tmp]
        if ok == false {
            dic[tmp] = idx

            ret = append(ret, []string{})
            ret[idx] = append(ret[idx], str)
            idx++
        } else {
            ret[val] = append(ret[val], str)
        }
    }
    return ret
}

相关文章

  • 体侧不能要命的一天

    2019-09-29 周日 天气晴 体侧不能要命的一...

  • hyperf| hyperf 编程入门小结 1

    date: 2019-09-29 23:58:16title: hyperf| hyperf 编程入门小结 1 最...

  • hyperf| hyperf 编程入门小结 1

    date: 2019-09-29 23:58:16title: hyperf| hyperf 编程入门小结 1 最...

  • 20190929日精进打卡第421天

    黄小燕Vicky 字数 726 · 阅读 2 2019-09-29 00:04 姓名:黄小燕 公司:新时代健康产业...

  • 注射玻尿酸隆鼻👃Dr.Duxi

    注射隆鼻应该要注意哪些事项? 关注 字数 5630 · 阅读 139 2019-09-29 21:09 注射隆鼻 ...

  • 2019-09-29

    2019-09-28 2019-09-29 姓名:符振华(379期 反省三组) 公司:深圳蔚蓝时代商业管理有限公司...

  • ❄️独自凉

    风吹宿雨点点凉 树辞红叶片片伤 澹水深处独钓云 却见天际雁远航 ym 2019-09-29

  • 数组(Array)

    创建时间:2019-09-10 最后修改时间:2019-09-29 数组的索引值从0开始,而数组的长度Array....

  • 戀愛手記 (序)

    原创 Y zoe Under the clitoris 2019-09-29 自從我從大學開始到現在經歷過四段基本...

  • 2019-09-29

    2019-09-29 打卡人:王素琴 公司:阜阳市豹子头服饰科技有限公司【日精进打卡第514天 【知~学习】 姓...

网友评论

      本文标题:2019-09-29

      本文链接:https://www.haomeiwen.com/subject/eqbxyctx.html