219. 在排序链表中插入一个节点

219. 在排序链表中插入一个节点

中文English

在链表中插入一个节点。

样例

样例 1:

输入:head = 1->4->6->8->null, val = 5
输出:1->4->5->6->8->null

样例 2:

输入:head = 1->null, val = 2
输出:1->2->null
第一个版本:
"""
Definition of ListNode
class ListNode(object):
    def __init__(self, val, next=None):
        self.val = val
        self.next = next
"""

class Solution:
    """
    @param head: The head of linked list.
    @param val: An integer.
    @return: The head of new linked list.
    """
    def insertNode(self, head, val):
        # write your code here
        new_node = ListNode(val)
        #边界情况
        if not head: return None
        if head.val >= val: 
            new_node.next = head 
            return new_node
        
        p = head
        
        while p.next:
            #如果在中间的话,则直接返回
            if val > p.val and val <= p.next.val:
                new_node.next = p.next
                p.next = new_node
                return head
            else:
                p = p.next 
        else:
            #如果不在中间
            p.next = new_node
        
        return head 
        

 

第二个版本:

"""
Definition of ListNode
class ListNode(object):
    def __init__(self, val, next=None):
        self.val = val
        self.next = next
"""

class Solution:
    """
    @param head: The head of linked list.
    @param val: An integer.
    @return: The head of new linked list.
    """
    def insertNode(self, head, val):
        # write your code here
        #一直到val < p.next.val 的时候退出
        dummy = ListNode(0)
        dummy.next = head 
        
        p = dummy 
        while p.next  and val < p.next.val:
            p = p.next
        
        #开始拼接
        new_node = ListNode(val, p.next)
        p.next = new_node
        
        return head 
 
posted @ 2020-08-15 13:54  风不再来  阅读(299)  评论(0编辑  收藏  举报