leetcode-5.14[414. 第三大的数、709. 转换成小写字母、766. 托普利茨矩阵](python实现)

题目1

在这里插入图片描述

题解1

class Solution:
    def thirdMax(self, nums: List[int]) -> int:
        # 集合去重
        nums = list(set(nums))
        if len(nums) <= 2:
            return max(nums)
        # 三次选择排序O(3n) -> O(n)
        for i in range(3):
            max_index = i
            for j in range(i+1, len(nums)):
                if nums[j] > nums[max_index]:
                    max_index = j
            nums[i], nums[max_index] = nums[max_index], nums[i]
        return nums[2]

附上题目链接

题目2

在这里插入图片描述

题解2

class Solution:
    def toLowerCase(self, str: str) -> str:
        for s in str:
            if ord(s) >= 65 and ord(s) <= 90:
                str = str.replace(s,chr(ord(s)+32))
        return str

        # 简洁写法
        # return ''.join([chr(ord(c)+32) if ord(c)>=65 and ord(c)<=90 else c for c in str])

附上题目链接

题目3

在这里插入图片描述

题解3

class Solution:
    def isToeplitzMatrix(self, matrix: List[List[int]]) -> bool: 
        # r1 - c1 == r2 - c2, 一组矩阵的x-y等于一个定值
        groups = {}
        for r, row in enumerate(matrix):
            for c, val in enumerate(row):
                if r-c not in groups:
                    groups[r-c] = val
                elif groups[r-c] != val:
                    return False
        return True

附上题目链接

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值