자바 스 택 의 체인 스 택 저장 구조의 실현 코드
사슬 창고
단일 체인 시트 로 스 택 의 모든 요 소 를 저장 하 는데 이런 체인 구조의 스 택 을 체인 스 택 이 라 고 합 니 다.
2. 스 택 의 체인 저장 구조 실현
package com.ietree.basic.datastructure.stack;
/**
 *   
 *
 * Created by ietree
 * 2017/4/29
 */
public class LinkStack {
  //        Node,Node         
  private class Node {
    //        
    private T data;
    //          
    private Node next;
    //      
    public Node() {
    }
    //            
    public Node(T data, Node next) {
      this.data = data;
      this.next = next;
    }
  }
  //           
  private Node top;
  //              
  private int size;
  //      
  public LinkStack() {
    //    ,top   null
    top = null;
  }
  //             ,         
  public LinkStack(T element) {
    top = new Node(element, null);
    size++;
  }
  //        
  public int length() {
    return size;
  }
  //   
  public void push(T element) {
    //  top        ,    next           
    top = new Node(element, top);
    size++;
  }
  //   
  public T pop() {
    Node oldTop = top;
    //  top               
    top = top.next;
    //         next  
    oldTop.next = null;
    size--;
    return oldTop.data;
  }
  //       ,        
  public T peek(){
    return top.data;
  }
  //          
  public boolean empty() {
    return size == 0;
  }
  //     
  public void clear() {
    top = null;
    size = 0;
  }
  public String toString() {
    //       
    if (empty()) {
      return "[]";
    } else {
      StringBuilder sb = new StringBuilder("[");
      for (Node current = top; current != null; current = current.next) {
        sb.append(current.data.toString() + ", ");
      }
      int len = sb.length();
      return sb.delete(len - 2, len).append("]").toString();
    }
  }
}   테스트 클래스:
package com.ietree.basic.datastructure.stack;
/**
 * Created by ietree
 * 2017/4/29
 */
public class LinkStackTest {
  public static void main(String[] args) {
    LinkStack stack = new LinkStack();
    stack.push("aaaa");
    stack.push("bbbb");
    stack.push("cccc");
    stack.push("dddd");
    System.out.println(stack);
    System.out.println("      :" + stack.peek());
    System.out.println("         :" + stack.pop());
    System.out.println("         :" + stack.pop());
    System.out.println("  pop    :" + stack);
  }
}    프로그램 출력:
[dddd, cccc, bbbb, aaaa]
      :dddd
         :dddd
         :cccc
  pop    :[bbbb, aaaa]  읽 어 주 셔 서 감사합니다. 여러분 에 게 도움 이 되 기 를 바 랍 니 다. 본 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.