zoukankan      html  css  js  c++  java
  • Java数据结构

    class Node {
        // 节点内容
        private int data;
        // 下一个节点
        private Node next;
    
        public Node(int value) {
            this.data = value;
        }
    
        // 为节点追加节点
        public Node append(Node node) {
            // 当前节点
            Node currentNode = this;
            // 循环向后找
            while(true) {
                // 如果下一个节点为null, 说明当前节点已经是最后一个节点
                if (currentNode.next == null) {
                    break;
                }
                currentNode = currentNode.next;
            }
            // 把需要追加的节点追加为找到的当前节点的下一个节点
            currentNode.next = node;
            return this;
        }
    
        // 获取下一个节点
        public Node next() {
            return this.next;
        }
    
        // 获取节点中的数据
        public int getData() {
            return this.data;
        }
    
        // 当前节点是否是最后一个节点
        public boolean isLast() {
            return this.next == null;
        }
    
        // 删除下一个节点
        public void removeNext() {
            // 先取出下下一个节点
            Node nextNextNode = next.next;
            // 把下下一个节点设置为当前节点的下一个节点
            this.next = nextNextNode;
        }
    
        // 显示所有节点信息
        public void show() {
            Node currentNode = this;
            while (true) {
                System.out.print(currentNode.data+" ");
                // 取出下一个节点
                currentNode = currentNode.next;
                if (currentNode == null) {
                    break;
                }
            }
            System.out.println();
        }
    
        // 插入一个节点作为当前节点的下一个节点
        public void insert(Node node) {
            // 取出下一个节点,作为下下一个节点
            Node nextNode = next;
            // 把新节点作为当前节点的下一个节点
            this.next = node;
            // 把下下一个节点设置为新节点的下一个节点
            node.next = nextNode;
        }
    }
    
    public class Main {
        public static void main(String[] args) {
            // 创建节点
            Node n1 = new Node(1);
            Node n2 = new Node(2);
            Node n3 = new Node(3);
    
            // 追加节点
            n1.append(n2).append(n3);
    
            // 取出下一个节点
            System.out.println(n1.next().next().getData());
    
            // 判断节点是否为最后一个节点
            System.out.println(n1.next().next().isLast());
    
            // 显示所有节点内容
            n1.show();
    
            // 删除一个节点
            n1.removeNext();
            n1.show();
            
            // 插入一个新节点
            n1.insert(new Node(2));
            n1.show();
    
            
        }
    }
  • 相关阅读:
    K-means聚类算法
    实现计算出用户间的共同好友和二度好友
    Mysql和Hive实现列转行,类似reduceByKey操作
    Flink两阶段提交概述
    一些推荐算法的面试题
    收藏推荐算法-机器学习相关博客文章
    Notepad++将多行数据合并成一行
    布隆过滤器
    二叉树问题
    海量数据常见面试问题
  • 原文地址:https://www.cnblogs.com/GjqDream/p/11592252.html
Copyright © 2011-2022 走看看