7.18 - medium总结17

323. Number of Connected Components in an Undirected Graph: 这题算是比较典型的图的问题,有三种解法,bfs,dfs,union-find:

class Solution(object):
    def countComponents(self, n, edges):
        """
        :type n: int
        :type edges: List[List[int]]
        :rtype: int
        """
        m = range(n)
        res = set()
        # union-find的含义就是找到某个节点的最终的root
        # 在这里,因为用index作为map的key
        # 对于每一条边,每加入一个边,就检查两个点,e[0]为root,e[1]为child
        # 看看这两个点的最终father是谁,然后再把这两个最终father联系起来
        for e in edges:
            self.union(m, e[0], e[1])
        # 用一个set记录所有的最终father的数量
        for i in m:
            res.add(self.find(m, i))
        return len(res)

    def find(self, m, node):
        if node == m[node]:
            return node
        return self.find(m, m[node])
    
    def union(self, m, node1, node2):
        father1 = self.find(m, node1)
        father2 = self.find(m, node2)
        if father1 != father2:
            m[father2] = father1

class Solution(object):
    def countComponents(self, n, edges):
        """
        :type n: int
        :type edges: List[List[int]]
        :rtype: int
        """     
        visited = [0] * n
        g = {x:[] for x in xrange(n)} # g[n] 表示n 和哪些值相连接, 其实就是用list和map构造一个图的表示形式。
        for x, y in edges:
            g[x].append(y)
            g[y].append(x)
            
        ret = 0
        for i in xrange(n): # 对于每一个节点,如果没有被访问过,就对其进行dfs
            if visited[i] == 0:
                self.dfs(i, g, visited) # 每遍历一次连接,就在ret上加一
                ret += 1
                
        return ret
    
    def dfs(self, n, g, visited):
        if visited[n]:
            return
        visited[n] = 1
        for x in g[n]:
            self.dfs(x, g, visited)
class Solution(object):
    def countComponents(self, n, edges):
        """
        :type n: int
        :type edges: List[List[int]]
        :rtype: int
        """
        # bfs也类似,也要创造出图的表示方式
        g = {x:[] for x in xrange(n)}
        visited = [0 for _ in range(n)]
        for x, y in edges:
            g[x].append(y)
            g[y].append(x)
            
        ret = 0
        for i in xrange(n):
            if visited[i] == 0:
                # 如果没有被visited过,则创建一个新的queue
                queue = [i]
                ret += 1
                while queue:
                    j = queue.pop(0)
                    visited[j] = 1
                    for k in g[j]:
                        if visited[k] == 0:
                            queue += [k]

        return ret

324. Wiggle Sort II: sort一下再排序就好了,但是如果要O(N)的复杂度,O(1)的space的话,需要用到quick select, 但是接下来怎么做实在是太复杂了,感觉意义不是很大
325. Maximum Size Subarray Sum Equals k: 利用前缀和,虽然自己的解法AC了,但是有比较好的解法,在loop过程中直接计算前缀和,然后利用hash来记录
328. Odd Even Linked List: 用一个even和一个odd来分别记录,然后拼起来就行了
331. Verify Preorder Serialization of a Binary Tree:没做出来,感觉体力被那道wiggle sort耗尽了,这题的思路其实也不难,就是碰到两个#就把它们从stack pop出来,再pop出来它们的parent并且push一个#进去。循环这么做就可以了。体力耗尽就是心浮气躁。先休息一下再做。

class Solution(object):
    def isValidSerialization(self, preorder):
        """
        :type preorder: str
        :rtype: bool
        """
        stack = []
        top = -1
        preorder = preorder.split(',')
        for s in preorder:
            stack.append(s)
            top += 1
            while(self.endsWithTwoHashes(stack,top)):
                h = stack.pop()
                top -= 1
                h = stack.pop()
                top -= 1
                if top < 0:
                    return False
                h = stack.pop()
                stack.append('#')
        if len(stack) == 1:
            if stack[0] == '#':
                return True
        return False

    def endsWithTwoHashes(self,stack,top):
        if top<1:
            return False
        if stack[top]=='#' and stack[top-1]=='#':
            return True
        return False

332. Reconstruct Itinerary: 休息了一下,沉下心来,用backtracking作出一个TLE版本,还可以接受。不过DFS的正确打开方式如解法2,详细解释:https://discuss.leetcode.com/topic/36370/short-ruby-python-java-c, 我觉得我能做出TLE的已经满足了,解法2只能背下来,真正面试时候属于知道就知道,不知道就拉倒的解法。。。

class Solution(object):
    def findItinerary(self, tickets):
        """
        :type tickets: List[List[str]]
        :rtype: List[str]
        """
        m = {}
        for i in range(len(tickets)):
            m[tickets[i][0]] = m.get(tickets[i][0], [])+ [i] # 从这个t[0] 出发,用了第几张票
        
        used = [False for _ in range(len(tickets))]
        self.res = []
        self.dfs(m, ["JFK"], used, tickets)
        return self.res
        
    
    def dfs(self, m, cur, used, tickets):
        if len(cur) == len(tickets)+1:
            if not self.res or self.res > cur:
                self.res = cur[:]
            return
        for c in m.get(cur[-1], []):
            if used[c]:
                continue
            used[c] = True
            cur.append(tickets[c][1])
            self.dfs(m, cur, used, tickets)
            cur.pop()
            used[c] = False
class Solution(object):
    def findItinerary(self, tickets):
        """
        :type tickets: List[List[str]]
        :rtype: List[str]
        """
        # build graph
        graph = {}
        for t in tickets:
            graph[t[0]] = graph.get(t[0], []) + [t[1]]
        
        for k, v in graph.iteritems():
            graph[k] = sorted(v)
        
        departure = "JFK"
        path = []
        self.dfs(graph, departure, path)
        
        return path
    
    def dfs(self, graph, departure, path):
        arrivals = graph.get(departure)
        while arrivals:
            self.dfs(graph, arrivals.pop(0), path)
        path.insert(0, departure)
                

333. Largest BST Subtree: 还算是简单的divide and conquer
334. Increasing Triplet Subsequence:可以记录前两个最小值,或者记录一下两位上升序列中的后一个值。
337. House Robber III:divide and conquer,返回值分成with root和without root两种情况就可以了
338. Counting Bits:一道dp题,推导公式如下: if i < 2**(k+1): dp[i] = dp[i-2**k] + 1 elif i == 2**(k+1): k += 1, dp[i] = 1

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

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,743评论 0 33
  • 导语: 如果你已经加入了iOS攻城狮队伍,那么我们由衷地祝贺您正式成为一名终身学习的程序猿;有人觉得这句话...
    超人猿阅读 2,290评论 3 19
  • //作者:JRZAlan //备注:第一次做简书,希望能对大家起到帮助。 这是对一些计算机编程语言的一些英语单词,...
    JRZAlan阅读 16,817评论 0 77
  • LeetCode 刷题随手记 - 第一部分 前 256 题(非会员),仅算法题,的吐槽 https://leetc...
    蕾娜漢默阅读 17,744评论 2 36
  • 你如何在看似悠悠如水的岁月里,可以陪伴自己好好走一段,然后也去看待人世间的不圆满,但却用自己的眼光,自己的身体力行...
    w00ds阅读 200评论 0 0