2019-09-29

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
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

  • 一元就能买包啦! 女生的世界里总少不了各种各样好看的包包 “包”你满意 “包”治百病 真正的一块钱买不了吃亏和上当...
    超喜欢奶茶呀阅读 149评论 0 0
  • 终于敢赤裸回忆那段时光。 孩子不在身边,连回忆都得深锁。即使是糖爸也没办法完全理解,心被撕扯的感觉。也把很...
    漓峦阅读 205评论 0 0
  • 常常把自己当成研究的对象[呲牙][偷笑],保持一份觉察,保持一点距离… 渐渐的,就会除了对自己有更多的了解,而且对...
    凤凰未涅槃阅读 65评论 0 0
  • 上周六,带丞丞去走了“灵白线”,从灵岩山开始,穿过天平山,到达白马涧,中途翻越4座山头,历时4个小时,作为登...
    单军民阅读 245评论 0 0
  • javascript中对时间的表达 前面的资料从网上找来的(https://www.cnblogs.com/xia...
    祝我好运zz阅读 183评论 0 1