[leetcode in golang]83、删除排序链表中的重复元素

aside section ._1OhGeD · · 809 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

/**
 * Definition for singly-linked list.
* type ListNode struct {
*     Val int
*     Next *ListNode
* }
*/
func deleteDuplicates(head *ListNode) *ListNode{
    if head==nil||head.Next==nil{
        return nil
    }
    for head!=nil&&head.Next!=nil{
        if head.Val==head.Next.Val{
            head.Next=head.Next.Next
        }else{
            head=head.Next
        }
        return head
    }
    return nil
/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func deleteDuplicates(head *ListNode) *ListNode {
    if head==nil||head.Next==nil{
        return nil
    }
    cur:=head
    for cur!=nil&&cur.Next!=nil{
        if cur.Val==cur.Next.Val{
            cur.Next=cur.Next.Next
        }else{
            cur=cur.Next
        }
        
    }
    return head
}

83、有递归和非递归两种方法,第一种方法不能处理倒数两个数为重复元素,经过查找找到了用cur指针复制,没有找原因。
在测试用例为[1]时,返回nil是错误的,应该直接返回head节点
head是头结点,cur是引进的指针

/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func deleteDuplicates(head *ListNode) *ListNode {
    if head==nil||head.Next==nil{
        return head
    }
    if head.Val == head.Next.Val {
            return deleteDuplicates(head.Next);
        } else {
            head.Next = deleteDuplicates(head.Next);
        }
    return head
}

采用递归算法不需要引进指针,两种方法的内存消耗相差无几,但是递归的执行用时是非递归的二分之一


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:aside section ._1OhGeD

查看原文:[leetcode in golang]83、删除排序链表中的重复元素

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

809 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传