算法笔记(中序、 相同的树、2的幂)

二叉树的中序遍历(js)

主要思路:中序遍历是按照左子树——根节点——右子树的方式遍历,而访问左子树或者右子树时可以按照同样的方式遍历符合递归的性质,终止条件为访问到空节点,如果二叉树的左子树存在继续递归直到左子树不存在,将此时的节点值加入,看右子树是否存在,有则对右子树进行递归,直到右子树不存在,将值加入数组中。

 相同的树

 主要思路:先判断有没有节点,如果都没有节点则相同,否则如果其中一个没有节点不相同,否则如果第一个节点不相同则两棵树不同,否则对左子树和右子树分别递归,两者均为true则两树相同,否则两树不同。

class Solution {
    public boolean isSameTree(TreeNode p, TreeNode q) {
if(p==null&&q==null){return true;}
else if(p==null||q==null){ return false;}
else if(p.val!=q.val)return false;
else return isSameTree(p.left,q.left)&&isSameTree(p.right,q.right);
    }
}

 2的幂

主要思路:关键:一个数 n 是 22的幂,当且仅当 n 是正整数,并且 n的二进制表示中仅包含 1个 1。& 表示按位与运算,加入n的二进制为(a10....0),a表示若干个高位0,n-1变成(a0,...1),两个进行与运算得到0,此时表示这个数是2的幂。

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值