题解 | #从单向链表中删除指定值的节点#

从单向链表中删除指定值的节点

http://www.nowcoder.com/practice/f96cd47e812842269058d483a11ced4f

import java.util.Objects; import java.util.Scanner;

public class Main {

public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    while (sc.hasNext()) {
        int size = sc.nextInt();
        int startNode = sc.nextInt();
        ListNode pre = new ListNode(startNode);
        ListNode.size = 1;
        size--;
        while (size > 0) {
            int nodeValue = sc.nextInt();
            int preValue = sc.nextInt();
            ListNode cur = pre;
            int curSize = ListNode.size;
            for (int i = 0; i < curSize; i++) {
                if (cur.value == preValue) {
                    ListNode temp = cur.next;
                    cur.next = new ListNode(nodeValue);
                    ListNode.size++;
                    cur.next.next = temp;
                }
                cur = cur.next;
            }
            size--;
        }
        int removeValue = sc.nextInt();
        ListNode cur = pre;
        if (removeValue == cur.value) {
            pre = cur.next;
        } else {
            while (!Objects.isNull(cur.next)) {
                if (removeValue == cur.next.value) {
                    cur.next = cur.next.next;
                }
                cur = cur.next;
            }
        }
        cur = pre;
        while (!Objects.isNull(cur)) {
            System.out.print(cur.value + " ");
            cur = cur.next;
        }
    }
}

private static class ListNode {
    static int size;
    
    int value;
    
    ListNode next;
    
    public ListNode(int value) {
        this.value = value;
    }
}

}

全部评论

相关推荐

RajahnRan:公司赚到了,这可是一眼就手写出来的代码,ai都写不出来
点赞 评论 收藏
分享
未知的命运:大佬这都找不到我还找啥啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务