剑指Offer之Java算法习题精讲二叉树与斐波那契函数
题目一
文章图片
【剑指Offer之Java算法习题精讲二叉树与斐波那契函数】解法
class Solution {public int fib(int n) {int[] arr = new int[31]; arr[0] = 0; arr[1] = 1; for(int i = 2; i<=n; i++){arr[i] = arr[i-2]+arr[i-1]; }return arr[n]; }}
题目二
文章图片
解法
/** * Definition for a binary tree node. * public class TreeNode { *int val; *TreeNode left; *TreeNode right; *TreeNode() {} *TreeNode(int val) { this.val = val; } *TreeNode(int val, TreeNode left, TreeNode right) { *this.val = val; *this.left = left; *this.right = right; *} * } */class Solution {int index = 0; int ans = 0; public int kthSmallest(TreeNode root, int k) {method(root,k); return ans; }void method(TreeNode root, int k){if(root==null) return; method(root.left,k); index++; if(index==k){ans = root.val; return; }method(root.right,k); }}
题目三
文章图片
解法
/** * Definition for a binary tree node. * public class TreeNode { *int val; *TreeNode left; *TreeNode right; *TreeNode() {} *TreeNode(int val) { this.val = val; } *TreeNode(int val, TreeNode left, TreeNode right) { *this.val = val; *this.left = left; *this.right = right; *} * } */class Solution {public int minDepth(TreeNode root) {if (root == null) {return 0; }if (root.left == null && root.right == null) {return 1; }int min_depth = Integer.MAX_VALUE; if (root.left != null) {min_depth = Math.min(minDepth(root.left), min_depth); }if (root.right != null) {min_depth = Math.min(minDepth(root.right), min_depth); }return min_depth + 1; }}
到此这篇关于剑指Offer之Java算法习题精讲二叉树与斐波那契函数的文章就介绍到这了,更多相关Java二叉树与斐波那契函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 剑指Offer之Java算法习题精讲排列与N叉树
- 剑指Offer之Java算法习题精讲链表专题篇
- 剑指Offer之Java算法习题精讲二叉树专题篇下
- 剑指Offer之Java算法习题精讲二叉树与N叉树
- 不归路之Python|什么是计算机网络(为什么需要网络通信?如何进行网络编程?)
- Python自动化办公之邮件发送全过程详解
- Unity实战之FlyPin(见缝插针)小游戏的实现
- 手写|手写 Vue2 系列 之 patch —— diff
- leetcode|算法入门之字符串(Python)【初级算法——字符串】【蓝桥杯练习】【力扣练习】
- redis|秒杀项目前期之登录功能