栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

leetcode学习笔记(合并有序数组/加1)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

leetcode学习笔记(合并有序数组/加1)

88. 合并两个有序数组

傻子解法
class Solution:
    def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:
        for i in range(n):
            nums1[m+i] = nums2[i]
        nums1.sort()
        return nums1
不用sort
class Solution:
    def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:
        len1 = m-1
        len2 = n-1
        len3 = m+n-1
        while  len2 >= 0 :
            if len1 >= 0:
                if nums2[len2] > nums1[len1]:
                    nums1[len3] = nums2[len2]
                    len2 -= 1
                    len3 -= 1
                else:
                    nums1[len3] = nums1[len1]
                    len1 -= 1
                    len3 -= 1 
            else:
                nums1[len3] = nums2[len2]
                len3 -= 1
                len2 -= 1 
66. 加一

从后向前
class Solution:
    def plusOne(self, digits: List[int]) -> List[int]:
        for i in range(len(digits)-1, -1, -1):
            digits[i] += 1
            if digits[i] < 10:
                return digits
            else:
                digits[i] = 0
        return [1] + digits #[9,9,9]情况
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/296009.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号