2

独自のキュー クラスを作成しようとしています。私のエンキュー メソッドは 1 つのオブジェクトのみをエンキューし、それ以外のものをエンキューしようとすると、ほとんどそれを無視するようになります。これが私のコードです:

public class myQueue {

    private Node front;
    private Node back;
    private int s;

    public myQueue() {
            front = null;
            back = null;
            s = 0;
    }

    public void enqueue(Object x) {
        if( isEmpty() )
            back = front = new Node(x);
        else
            back = back.next = new Node(x);
        s++;
    }

    public Object dequeue() {
        Object x;
        if( isEmpty() ) { System.out.println("nothing to dequeue.\nqueue empty."); }
        x = front.data;
        s--;
        return x;
    }

    public boolean isEmpty() {
        if(s == 0)
            return true;
        else
            return false;
    }

    public void printQueue() {
        if ( isEmpty() )
            System.out.println("empty queue");
        else {
            Node temp = back;
            while(temp != null) {
                System.out.println(temp);
                temp = temp.next;
            }
        }   
    }



}

そして、ここにいくつかのオブジェクトをエンキューしようとする私の主な方法があります:

public static void main(String[] args) {
    int a = 5;
    String b = "yo";
    Object c = 5.5;                
    int d = 2;
    String e = "Pen";
    Object f = 9.2;

    myQueue q = new myQueue();

    q.enqueue(a);
    q.enqueue(b);
    q.enqueue(c);
    q.enqueue(d);
    q.enqueue(e);
    q.enqueue(f);

    System.out.println("\n");

    q.printQueue();
}

そして、出力のために得られるのは次のとおりです。

データ: 9.2

なぜこれが起こっているのかについてのアイデアはありますか?

4

1 に答える 1

2

印刷するときは、列の最後尾から開始します。先頭から開始する必要があります。

        Node temp = front; // <<< replacing back by front
        while(temp != null) {
            System.out.println(temp);
            temp = temp.next;
        }

キューの最後から開始すると、キューの最後の要素のみが印刷されます...

修正後の私の結果:

data : 5
data : yo
data : 5.5
data : 2
data : Pen
data : 9.2
于 2013-02-22T01:49:35.443 に答える