美文网首页
常见数据结构-Java

常见数据结构-Java

作者: GIT提交不上 | 来源:发表于2020-05-21 20:12 被阅读0次

一、链表

public class ListNode{
    int val;
    ListNode next;
    ListNode(int x){
        val = x;
    }
}

二、二叉树

public class TreeNode {
    int val;
    TreeNode leftNode;
    TreeNode rightNode;
    TreeNode(int x) {
        val = x;
    }
}
  • 前序遍历-先输出当前结点的数据,再依次遍历输出左结点和右结点
  • 中序遍历-先遍历输出左结点,再输出当前结点的数据,再遍历输出右结点
  • 后序遍历- 先遍历输出左结点,再遍历输出右结点,最后输出当前结点的数据
  • 已知前序遍历和后序遍历,无法确定一颗唯一的二叉树
//已知前序和中序
public TreeNode buildTree(int[] preorder, int[] inorder) {
    if (preorder == null || preorder.length == 0) {
        return null;
    }
    Map<Integer, Integer> indexMap = new HashMap<Integer, Integer>();
    int length = preorder.length;
    for (int i = 0; i < length; i++) {
        indexMap.put(inorder[i], i);
    }
    TreeNode root = buildTree(preorder, 0, length - 1, inorder, 0, length - 1, indexMap);
    return root;
}

public TreeNode buildTree(int[] preorder, int preorderStart, int preorderEnd, int[] inorder, int inorderStart, int inorderEnd, Map<Integer, Integer> indexMap) {
    if (preorderStart > preorderEnd) {
        return null;
    }
    int rootVal = preorder[preorderStart];
    TreeNode root = new TreeNode(rootVal);
    if (preorderStart != preorderEnd) {
        //获取根节点在中序遍历的index
        int rootIndex = indexMap.get(rootVal);
        //获取根节点左右的开始index
        int leftNodes = rootIndex - inorderStart, rightNodes = inorderEnd - rootIndex;
        TreeNode leftSubtree = buildTree(preorder, preorderStart + 1, preorderStart + leftNodes, inorder, inorderStart, rootIndex - 1, indexMap);
        TreeNode rightSubtree = buildTree(preorder, preorderEnd - rightNodes + 1, preorderEnd, inorder, rootIndex + 1, inorderEnd, indexMap);
        root.left = leftSubtree;
        root.right = rightSubtree;
    }
    return root;
}

相关文章

  • 数据结构

    Java数据结构 常见的数据结构 HashMap 迭代方式: keyset entryset 比较:keyset比...

  • 复习

    数据结构 数据结构 集合常见数据结构:集合,链表,队列,数组,栈,映射java中:List列表,Set集合,Map...

  • Java集合框架

    Java集合框架 (例如基本的数据结构)里包含了最常见的Java常见面试问题。很好地理解集合框架,可以帮助你理解和...

  • Java集合框架面试问题集锦

    Java集合框架(例如基本的数据结构)里包含了最常见的Java常见面试问题。很好地理解集合框架,可以帮助你理解和利...

  • Java数据结构和算法概览

    Java数据结构和算法概览 数据结构 线性数据结构:常见的有一维数组,线性表,栈,队列,双队列,串。 非线性数据结...

  • 2019-08-04-Android性能优化方法总结

    1,代码优化 选择正确的数据结构。Java中常见的数据结构,List,Map以及实现类等。Android也提供了一...

  • Java基础——数据结构和算法

    1、Java中常见的数据结构 理解数据结构和算法对于编程是相当重要的,选择适当的数据结构来解决相应的问题,会极大的...

  • 链表、递归、堆、Hashmap、归并排序算法

    java数据结构——链表 链表(Linked list)是一种常见的基础数据结构,是一种线性表,但是并不会按线性的...

  • Java编程基础(9)

    Java编程基础- Java数组-针对数组(Array)的各种操作: 数组是最常见的一种数据结构,它是相同类型的用...

  • java常见的数据结构

网友评论

      本文标题:常见数据结构-Java

      本文链接:https://www.haomeiwen.com/subject/ngitahtx.html