2017-09-25 20 views
0

リンクスタックに値を追加する際に、少なくとも値を出力する際に​​問題があります。私はたとえスタックに値を追加するためにこれを正しくコーディングしてもわかりません。私はこのために3つのクラス、Nodeクラス、LinkedStackクラス、およびプログラムを実行するドライバを作成しました。ここでカスタムLinkedStackメソッドのtoString()メソッドが追加されていません

は、Nodeクラスである:ここでは

public class Node 
{ 
    int data; 
    Node link; 

    //contructor 
    public Node(int d) 
    { 
     data = d; 
     link = null; 
    } 

    public int getData() 
    { 
     return data; 
    } 

    public Node getLink() 
    { 
     return link; 
    } 

    public void setData(int d) 
    { 
     data = d; 
    } 

    public void setLink(Node n) 
    { 
     link = n; 
    } 
} 

はLinkedStackクラスである:ここで

import java.util.NoSuchElementException; 

public class LinkedStack 
{ 

    //declare variables 
    private Node top; 
    private int size; 

    //constructor to initialize variables 
    public LinkedStack() 
    { 
     size = 0; 
     top = null; 
    } 

    //push method to add numbers to the stack 
    public void push(int value) 
    { 
     if(!isEmpty()) 
     { 
      top.setData(value); 
      size++; 
     } 
    } 

    //method to remove the top number in the stack 
    public int pop() 
    { 
     Node temp = top; 
     if(!isEmpty()) 
     { 
      temp = top; 
      size--; 
     } 

     return temp.getData(); 
    } 

    //boolean method to check if the stack is empty 
    public boolean isEmpty() 
    { 
     if(top == null) 
      return true; 
     else 
      return false; 
    } 

    //method to return the size of the stack 
    public int size() 
    { 
     return size; 
    } 

    //method to print out the top number in the stack 
    public int peek() 
    { 
     if (isEmpty() == true) 
     { 
      throw new NoSuchElementException("Stack is empty."); 
     } 
     else 
     { 
      return top.getData(); 
     } 
    } 

    //method to turn the stack into a String 
    public String toString() 
    { 
     String returnStr = "Stack: ["; 
     for(int i = 0 ; i < size; i++) 
     { 
      returnStr += top.getData() + ", "; 
     } 

     returnStr += "]"; 

     return returnStr; 
    } 
} 

は、ドライバー・クラスである:

import java.util.Scanner; 

public class Driver 
{ 
    public static void main(String[] args) 
    { 
     //declare variables and initialize scanner 
     Scanner key = new Scanner(System.in); 
     int size, choice, value, end; 

     end = 0; 

     //declare and initialize the stack 
     LinkedStack stack1 = new LinkedStack(); 

     //loop to continue operations 
     while(end == 0) 
     { 
      //print out menu for commands 
      System.out.println("\t1) Push \n\t2) Pop \n\t3) Peek \n\t4) Size \n\t5) isEmpty \n\t6) End"); 
      System.out.print("Please choose an option: "); 
      choice = key.nextInt(); 

      //switch the choice and execute commands 
      switch (choice) 
      { 
       case 1: System.out.println("Please enter a value: "); 
        value = key.nextInt(); 
        stack1.push(value); 
        System.out.println(stack1.toString()); 
        break; 
       case 2: stack1.pop(); 
        System.out.println(stack1.toString()); 
        break; 
       case 3: stack1.peek(); 
        System.out.println(stack1.toString()); 
        break; 
       case 4: System.out.println("Size: " + stack1.size()); 
        System.out.println(stack1.toString()); 
        break; 
       case 5: if(stack1.isEmpty()) 
       { 
        System.out.println("Stack is empty."); 
       } 
       else 
        System.out.println("Stack is NOT empty."); 
        System.out.println(stack1.toString()); 
        break; 
       case 6: end = 1; 
        System.out.println("Goodbye!"); 
        break; 
      } 
     } 
    } 
} 

私は取得しています問題は何もありませんスタックに印刷します。 ご協力いただきありがとうございます!あなたは私はあなたのメソッドの一部を更新Nodeオブジェクト

//push method to add numbers to the stack 
    public void push(int value) { 
     if(!isEmpty()){ 
      top.setData(value); 
      size++; 
     } else { 
      top = new Node(value); 
      size++; 
     } 
    } 
+1

'push()'メソッドは、新しい 'Node'を作成してそれをリストに追加する必要があります。 'Node'クラスの' link'メンバーを決して使用しないようです。 –

答えて

0

を初期化するのを忘れ

+0

ありがとう!これは多くの助けになります – Jdmon1998

0

、私は残りの方法は行ってもいいと思います。

public int pop() 
{ 
    Node temp = top; 
    if(!isEmpty()) 
    { 
     top = temp.link; 
     size--; 
    } else { 
      throw new IllegalAccessError(); 
    } 
    return temp.getData(); 
} 

public void push(int value) 
{ 
    Node node = new Node(value); 
    if(!isEmpty()) 
    { 
     node.link = top; 
     top = node;  
    } else { 
     top = node; 
    } 
    size++; 
} 
    public String toString() 
    { 
     String returnStr = "Stack: ["; 
     Node tmp = top; 
     while(tmp != null) { 
      returnStr += tmp.getData() + ", "; 
      tmp = tmp.link; 
     } 
     returnStr += "]"; 

     return returnStr; 
    } 
+0

これも同様に手助けをしました。私もあなたのものをチェックしますが、私は両方の答えを確認できません。 – Jdmon1998

関連する問題