剑指offer计划19( 搜索与回溯算法中等)---java

Posted URMkhaos的技术分享博客-Golang技术分享-Pyt

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer计划19( 搜索与回溯算法中等)---java相关的知识,希望对你有一定的参考价值。

1.1、题目1

剑指 Offer 64. 求1+2+…+n

1.2、解法

这题看评论区真的绝了,都是人才,各个说话都好听,我看到个还有用异常来结束的就离谱。
这题用了&&当左边为false,右边不执行的原理。

1.3、代码


class Solution {
    public int sumNums(int n) {
       boolean flag = n > 1 && (n += sumNums(n - 1)) > 0;
        return n;
    }
}


2.1、题目2

剑指 Offer 68 - I. 二叉搜索树的最近公共祖先

2.2、解法

因为是二叉搜索树,所以当前值大于两个值时,应该往左子树找,
当前值小于两个值时,应该往右子树找。

2.3、代码


class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(p.val<root.val && q.val < root.val)  {
            return lowestCommonAncestor(root.left,p,q);
        }else if(p.val>root.val && q.val >root.val){
            return lowestCommonAncestor(root.right,p,q);
        }else{
            return root;
        }
    }
}



3.1、题目3

剑指 Offer 68 - II. 二叉树的最近公共祖先

3.2、解法

开头判断是否是相同或者空的情况,然后设两个结点来遍历两边的字数,如果左边为空,则返回右边,
反之,则返回左边,两者都不满足,则返回root。

3.3、代码


class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root==null || root.val==p.val || root.val ==q.val) return root;
        TreeNode left = lowestCommonAncestor(root.left,p,q);
        TreeNode right = lowestCommonAncestor(root.right,p,q);
        if(left==null)  return right;
        if(right==null) return  left;
        return root;
    }

}

以上是关于剑指offer计划19( 搜索与回溯算法中等)---java的主要内容,如果未能解决你的问题,请参考以下文章

乱序版 ● 剑指offer每日算法题打卡题解—— 搜索与回溯算法(题号 40,45,61)

乱序版 ● 剑指offer每日算法题打卡题解—— 搜索与回溯算法(题号12,13,34)

乱序版 ● 剑指offer每日算法题打卡题解——搜索与回溯算法(题号37,38)

乱序版 ● 剑指offer每日算法题打卡题解—— 搜索与回溯算法 (题号26,27, 28)

⭐算法入门⭐《二叉树 - 二叉搜索树》中等01 —— LeetCode 剑指 Offer 33. 二叉搜索树的后序遍历序列

⭐算法入门⭐《二叉树 - 二叉搜索树》中等02 —— LeetCode 剑指 Offer 33. 二叉搜索树的后序遍历序列