欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

83、删除排序链表中的重复元素

程序员文章站 2022-05-10 19:59:38
...

问题描述

83、删除排序链表中的重复元素

问题分析

链表的简单模拟。就不过多赘述了。


解法:简单模拟

  • 时间复杂度:O( n ),其中n表示链表的长度。
  • 空间复杂度:O( 1 )

Java代码

package com.company;


public class Main {

    public static class ListNode {
        int val;
        ListNode next;
        ListNode(int x) { val = x; }
    }

    public static void main(String[] args) {

        ListNode listNode = new ListNode(1);
        listNode.next = new ListNode(1);
        listNode.next.next = new ListNode(2);
        listNode.next.next.next = new ListNode(3);
        listNode.next.next.next.next = new ListNode(3);

        ListNode result = deleteDuplicates(listNode);
        System.out.println(111);
    }

    static public ListNode deleteDuplicates(ListNode head) {

        //特殊情况处理
        if (head == null){
            return head;
        }


        //指针
        ListNode L = head;

        while (L.next != null){
            if (L.next.val == L.val){
                L.next = L.next.next;
            }else {
                L = L.next;
            }


        }

        return head;
    }
}

结果分析

以上代码的执行结果:

执行时间 内存消耗
1 ms 36.5 MB

83、删除排序链表中的重复元素

相关标签: 链表删除