zoukankan      html  css  js  c++  java
  • 练习题 (五)

    题目:

    Invert Binary Tree

    Invert a binary tree.

         4
       /   
      2     7
     /    / 
    1   3 6   9
    to
         4
       /   
      7     2
     /    / 
    9   6 3   1
    解答:
    # Definition for a binary tree node.
    # class TreeNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.left = None
    #         self.right = None
    
    class Solution:
        # @param {TreeNode} root
        # @return {TreeNode}
        def invertTree(self, root):
            if root is None:
                return None
            temp = root.left
            root.left = root.right
            root.right = temp
            
            self.invertTree(root.left)
            self.invertTree(root.right)
            return root
    

    心得:

    做这种面试题的时候,可以把二叉树的构造生成给省略掉,因为面试中,这不是重点,机考中,这是测试代码做的事情。

    题目本身不难,但是繁琐。这里并不需要前序便利或者中序遍历或者后序遍历,因为遍历是把树的二叉树结构转化成线性结构。但是我们并不需要转化成线性结构。

    大牛没有做出来,是因为大牛之所以为大牛,肯定是Think Diffirent的,根本没有去适应谷歌的面试。那么多的规划互联网上的软件的更新和适应工作环境的软件,就他设计出来的

    homebrew取得了最受欢迎的优势,肯定是他有难得的优点。但是谷歌确以此拒绝了他,我觉得这是谷歌的悲哀。

    当然,我作为菜鸟还是不要为大牛的前途担忧了。

  • 相关阅读:
    输出 n 层的三角形,倒三角和叠在一起的沙漏
    求构成给定自然数的平方数的最小个数
    求一正整数约数的个数
    第一个符合要求的元素
    树枝节点之和是否等于给定值
    安装gcc
    杭电1004 ac code
    rabbitmq 笔记
    国行 lg g3 D858 刷 lg g3 D858hk 教程(备忘)
    MySQL存储过程错误No data
  • 原文地址:https://www.cnblogs.com/ender-cd/p/4612419.html
Copyright © 2011-2022 走看看