一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 1186|回复: 1
收起左侧

[CS 61B Spring 2015] Discussion 9

[复制链接] |试试Instant~ |关注本帖
HNAKXR 发表于 2016-2-20 16:44:08 | 显示全部楼层 |阅读模式

[其他]CS 61B: Data Structures #9 - 2015-01-01@UC Berkeley

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
Discussion 9的内容是Binary Search Tree。
 楼主| HNAKXR 发表于 2016-2-20 16:48:05 | 显示全部楼层
  1. import java.util.Arrays;

  2. public class BSTNode {
  3.         public BSTNode left, right;
  4.         public int value;

  5.         public BSTNode(int n) {
  6.                 value = n;
  7.         }

  8.         public static int[] slice(int[] arr, int begin, int end) {
  9.                 if (begin < 0 || begin > arr.length || end < 0 || end > arr.length
  10.                         || begin >= end) {
  11.                         return null;
  12.                 }
  13.                 int[] result = new int[end - begin];
  14.                 for (int i = 0, j = 0; i < arr.length; i++) {
  15.                         if (i >= begin && i < end) {
  16.                                 result[j] = arr[i];
  17.                                 j++;
  18.                         }
  19.                 }
  20.                 return result;
  21.         }

  22.         public static BSTNode makeBST(int[] nums) {
  23.                 if (nums.length == 0) {
  24.                         return null;
  25.                 } else if (nums.length == 1) {
  26.                         return new BSTNode(nums[0]);
  27.                 }
  28.                 int mid = nums.length / 2;
  29.                 BSTNode result = new BSTNode(nums[mid]);
  30.                 result.left = makeBST(slice(nums, 0, mid));
  31.                 result.right = makeBST(slice(nums, mid + 1, nums.length));
  32.                 return result;
  33.         }

  34.         /* Returns the BSTNode that is the shortest common ancestor of n1 and n2. */
  35.         public static BSTNode commonAncestor(BSTNode root, int n1, int n2) {
  36.                 if (n1 > n2) {
  37.                         return null;
  38.                 }
  39.                 if (n1 <= root.value && n2 >= root.value) {
  40.                         return root;
  41.                 }
  42.                 if (n1 > root.value) {
  43.                         return commonAncestor(root.right, n1, n2);
  44.                 }
  45.                 if (n2 < root.value) {
  46.                         return commonAncestor(root.left, n1, n2);
  47.                 }
  48.                 return null;
  49.         }
  50. }
复制代码

评分

1

查看全部评分

回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-8 05:02

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表