码迷,mamicode.com
首页 > 编程语言 > 详细

python(2)

时间:2020-03-24 11:03:57      阅读:67      评论:0      收藏:0      [点我收藏+]

标签:sel   ret   sep   turn   style   int   info   图片   inf   

技术图片

 

 

 

技术图片
class Solution:
    def reversePrint(self, head: ListNode) -> List[int]:
        newList=[]
        while head:
            newList.append(head.val)
            head=head.next
        return newList[::-1]
View Code
技术图片
class Solution:
    def reversePrint(self, head: ListNode) -> List[int]:
        newList=[]
        if head != None:
            newList.append(head.val)
            head = head.next
            while head !=None:
                newList.append(head.val)
                head=head.next
            newList.reverse()
        return newList
View Code

利用递归: 先走至链表末端,回溯时依次将节点值加入列表 ,这样就可以实现链表值的倒序输出。

技术图片
递推阶段: 每次传入 head.next ,以 head == None(即走过链表尾部节点)为递归终止条件,此时返回空列表 [] 。
回溯阶段: 利用 Python 语言特性,递归回溯时每次返回 当前 list + 当前节点值 [head.val] ,即可实现节点的倒序输出。

作者:jyd
链接:https://leetcode-cn.com/problems/cong-wei-dao-tou-da-yin-lian-biao-lcof/solution/mian-shi-ti-06-cong-wei-dao-tou-da-yin-lian-biao-d/
来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
class Solution:
    def reversePrint(self, head: ListNode) -> List[int]:
        return self.reversePrint(head.next) + [head.val] if head else []
View Code

 

技术图片

 

 

 

技术图片
class CQueue:

    def __init__(self):
        self.stack1=[]
        self.stack2=[]


    def appendTail(self, value: int) -> None:
        self.stack1.append(value)


    def deleteHead(self) -> int:
        if self.stack2:
            return self.stack2.pop()
        elif not self.stack1:
            return -1
        else:
            while self.stack1:
                self.stack2.append(self.stack1.pop())
            return self.stack2.pop()
View Code

技术图片

 

 使用二分查找的方式:

技术图片
class Solution:
    def minArray(self, numbers: [int]) -> int:
        i, j = 0, len(numbers) - 1
        while i < j:
            m = (i + j) // 2
            if numbers[m] > numbers[j]: i = m + 1
            elif numbers[m] < numbers[j]: j = m
            else: j -= 1
        return numbers[i]
View Code
技术图片
class Solution:
    def minArray(self, numbers: [int]) -> int:
        return (min(numbers))
        
View Code

 

  

 

python(2)

标签:sel   ret   sep   turn   style   int   info   图片   inf   

原文地址:https://www.cnblogs.com/topass123/p/12557236.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!