在特定位置插入节点时的逻辑错误

Logical bug while inserting node at particular location

请考虑我下面的代码,假设链表已排序,在特定位置插入节点:

package datastructures;
public class Link {
    int data;
    Link next;

    public Link(int d){
        this.data = d;
    }

    public void displayLink(){
        System.out.println(data + " ");
    }
   
    public static class LinkList {
        Link first;

        public void insertFirst(int x) {
            Link newLink = new Link(x);
            newLink.next = first;
            first = newLink;
        }

        public Link deleteFirst() {
            Link temp = first;
            first = first.next;
            return temp;
        }

        public void displayList() {
            Link current = first;
            while (current != null) {
               current.displayLink();
               current = current.next;
            }
        }
                            
        public void insertNodeAtParticularLocation(int x){
            Link previous = first;
            Link current = first.next;

            if (first == null){
                // if node doesn't exist in the 
                // linkedlist then just create a new node
                Link newNode = new Link(x);
            } else if (x < first.data) {
                // Else if the value that needs to be inserted
                // is less than the first element, then insert 
                // it at the very beginning
                      
                Link newNode = new Link(x);
                newNode.next = first;
                first = newNode;
            } else {
                while(current.data > x){ // In case of21,22,23,27 ; If x = 24 , current should stop at 27
                    previous = current;
                    current = current.next;
                    Link newNode = new Link(x);
                    previous.next = newNode;
                    newNode.next = current;
                }
            }
        }
    }

    
    public static void main(String[] args) {
        
        LinkList addElements = new LinkList();
        
        addElements.insertFirst(21);
        addElements.insertFirst(22);
        addElements.insertFirst(23);
        addElements.insertFirst(27);
        addElements.insertFirst(29);
        
        System.out.println("Display Original Elements");
        
        addElements.displayList();
        
        addElements.insertNodeAtParticularLocation(24);
        
        System.out.println("Display Elements after First Modification");
        
        addElements.displayList();
    }
}

我的 insertNodeAtParticularLocation() 方法有问题。

问题 #1:

当我尝试添加 24 时,它仍然被添加到列表的末尾,而不是在指定的位置,该位置应该在值为 23.

的节点之后

问题 #2:

此外,我尝试添加另一个值 10,我希望它在开头添加,但它覆盖了最后一个元素 27 并被添加到它的位置。请让我知道我做错了什么。

存在多个问题:

insertFirst 将之前插入的元素推到后面。如果要在main中使用insertFirst,则需要颠倒顺序:

addElements.insertFirst(29);
addElements.insertFirst(27);
addElements.insertFirst(23);
addElements.insertFirst(22);
addElements.insertFirst(21);

insertNodeAtParticularLocation 存在一些问题:

  • 第一个 == null 情况不起作用,因为它没有首先分配
  • while 循环看起来可能会在错误的位置插入多个元素

我会这样写insertNodeAtParticularLocation

    public void insertNodeAtParticularLocation(int x) {
        if (first == null || x < first.data) {
            // if the value that needs to be inserted
            // is less than the first element, or it does not exist,
            // then insert it at the very beginning
            insertFirst(x);
        } else {
            Link previous = first;
            Link current = first.next;
            while(current != null && current.data > x) {
                previous = current;
                current = current.next;
            }
            Link newNode = new Link(x);
            previous.next = newNode;
            newNode.next = current;
        }
    }