剑指Offer之Java算法习题精讲二叉树与链表
题目一
文章图片
解法
/** * Definition for a binary tree node. * public class TreeNode { *int val; *TreeNode left; *TreeNode right; *TreeNode(int x) { val = x; } * } */class Solution {public boolean isBalanced(TreeNode root) {if(root==null){return true; }else{return Math.abs(method(root.left) - method(root.right)) <= 1&&isBalanced(root.left) && isBalanced(root.right); }}public int method(TreeNode root){if(root==null){return 0; }else{return Math.max(method(root.left),method(root.right))+1; }}}
题目二
文章图片
解法
/** * Definition for a binary tree node. * public class TreeNode { *int val; *TreeNode left; *TreeNode right; *TreeNode(int x) { val = x; } * } */class Solution {public boolean isSymmetric(TreeNode root) {if(root==null) return true; return method(root.left,root.right); }public boolean method(TreeNode l,TreeNode r){if(l==null&&r==null) return true; if(l==null||r==null||l.val!=r.val) return false; return method(l.left,r.right)&&method(l.right,r.left); }}
题目三
文章图片
解法
/** * Definition for singly-linked list. * public class ListNode { *int val; *ListNode next; *ListNode(int x) { val = x; } * } */class Solution {public ListNode deleteNode(ListNode head, int val) {ListNode temp = new ListNode(-1); temp.next = head; ListNode ans = temp; while(temp.next!=null){if(temp.next.val==val){temp.next = temp.next.next; }else{temp = temp.next; }}return ans.next; }}
题目四
文章图片
解法
/** * Definition for singly-linked list. * public class ListNode { *int val; *ListNode next; *ListNode(int x) { val = x; } * } */class Solution {public ListNode reverseList(ListNode head) {ListNode prev = null; ListNode curr = head; while (curr != null) {ListNode next = curr.next; curr.next = prev; prev = curr; curr = next; }return prev; }}
【剑指Offer之Java算法习题精讲二叉树与链表】到此这篇关于剑指Offer之Java算法习题精讲二叉树与链表的文章就介绍到这了,更多相关Java 二叉树内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 剑指Offer之Java算法习题精讲二叉树专项解析
- 剑指Offer之Java算法习题精讲排列与N叉树
- 剑指Offer之Java算法习题精讲二叉树与斐波那契函数
- 剑指Offer之Java算法习题精讲链表专题篇
- 剑指Offer之Java算法习题精讲二叉树专题篇下
- 剑指Offer之Java算法习题精讲二叉树与N叉树
- 不归路之Python|什么是计算机网络(为什么需要网络通信?如何进行网络编程?)
- Python自动化办公之邮件发送全过程详解
- Unity实战之FlyPin(见缝插针)小游戏的实现
- 手写|手写 Vue2 系列 之 patch —— diff