Java делает, пока цикл держит цикл, даже если он не соответствует условию

Мой while(cur!=head) должен выполняться на узле 4, так как он начинается на узле 3, программа выполняет оператор в do блокировать хотя бы один раз, затем он будет читать на узле 4, узел 4 совпадает с головным узлом, который является узлом 3.

Моя программа должна вернуться.

 Actual output: 3 3 3 3 4 5 1 2 

 Expected output: 3 3 3 4 5 1 2 3

Фактический результат правильный, мой ожидаемый результат неправильный. Однако мне просто интересно, когда cur равен head, что не соответствует условию while(cur!=head), но это может продолжать работать? Зачем?

class LinkedNode
{
    int val;
    LinkedNode next;
    LinkedNode (int x)
    {
        val = x;
        next = null;
    }
}



class Solution
{

    public static void main(String[] args)
    {
        LinkedNode node1 = new LinkedNode(1);
        LinkedNode node2 = new LinkedNode(2);
        LinkedNode node3 = new LinkedNode(3);
        LinkedNode node4 = new LinkedNode(3);
        LinkedNode node5 = new LinkedNode(3);
        LinkedNode node6 = new LinkedNode(3);
        LinkedNode node7 = new LinkedNode(4);
        LinkedNode node8 = new LinkedNode(5);

        node1.next = node2;
        node2.next = node3;
        node3.next = node4;
        node4.next = node5;
        node5.next = node6;
        node6.next = node7;
        node7.next = node8;
        node8.next = node1;

        LinkedNode after = check(node3);
        print_list(after);
    }


    public static void print_list(LinkedNode head)
    {   
        LinkedNode cur = head;
        do
        {
            System.out.print(head.val + " ");
            head = head.next;
        }
        while (cur!= head);//same question as the below
    }

    public static LinkedNode check(LinkedNode head)
    {   

        LinkedNode cur = head;
        do
        {   
            cur = cur.next;
        }   
        while(cur!=head);// this line is supposed to execute and exit at node4,since node4 is equal to node3(head)

        return cur;
    }

}

1 ответ

Решение

Вы сравниваете объекты по ссылке, а не по стоимости. Ваша логика верна. Узел 3 никогда не равен Узлу 4, поскольку они являются отдельными объектами, но вам нужно сравнить их значение.

while(cur.val != head.val)
Другие вопросы по тегам