【算法】算法题-20231112

算法题

  • [一、459. 重复的子字符串](#一、459. 重复的子字符串)
  • [二、414. 第三大的数](#二、414. 第三大的数)
  • [三、520. 检测大写字母](#三、520. 检测大写字母)
  • [四、680. 验证回文串 II](#四、680. 验证回文串 II)
  • [五、283. 移动零](#五、283. 移动零)

一、459. 重复的子字符串

简单

给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。

示例 1:

输入: s = "abab"

输出: true

解释: 可由子串 "ab" 重复两次构成。

示例 2:

输入: s = "aba"

输出: false

示例 3:

输入: s = "abcabcabcabc"

输出: true

解释: 可由子串 "abc" 重复四次构成。 (或子串 "abcabc" 重复两次构成。)

python 复制代码
def fun2(s):
    return s in (s + s)[1:-1]

s = "aba"
print(fun2(s))

二、414. 第三大的数

简单

给你一个非空数组,返回此数组中 第三大的数 。如果不存在,则返回数组中最大的数。

示例 1:

输入:[3, 2, 1]

输出:1

解释:第三大的数是 1 。

示例 2:

输入:[1, 2]

输出:2

解释:第三大的数不存在, 所以返回最大的数 2 。

示例 3:

输入:[2, 2, 3, 1]

输出:1

解释:注意,要求返回第三大的数,是指在所有不同数字中排第三大的数。

此例中存在两个值为 2 的数,它们都排第二。在所有不同数字中排第三大的数为 1 。

python 复制代码
def fun3(nums):
    nums.sort()
    if len(set(nums)) < 3:
        return nums[-1]
    else:
        return list(set(nums))[0]


nums = [3, 2, 1]
print(fun3(nums))

三、520. 检测大写字母

简单

我们定义,在以下情况时,单词的大写用法是正确的:

全部字母都是大写,比如 "USA" 。

单词中所有字母都不是大写,比如 "leetcode" 。

如果单词不只含有一个字母,只有首字母大写, 比如 "Google" 。

给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。

示例 1:

输入:word = "USA"

输出:true

示例 2:

输入:word = "FlaG"

输出:false

python 复制代码
def f1(word):
    if word.islower():
        return True
    elif word[0].isupper() and word[1:].islower():
        return True
    elif word.isupper():
        return True
    else:
        return False


word = "qlas"

print(f1(word))

四、680. 验证回文串 II

简单

给你一个字符串 s,最多 可以从中删除一个字符。

请你判断 s 是否能成为回文字符串:如果能,返回 true ;否则,返回 false 。

示例 1:

输入:s = "aba"

输出:true

示例 2:

输入:s = "abca"

输出:true

解释:你可以删除字符 'c' 。

示例 3:

输入:s = "abc"

输出:false

python 复制代码
def f3(s):
    start=0
    end=len(s)-1
    while start<end:
        if s[start]==s[end]:
            start+=1
            end-=1
        else:
            return s[start:end]==s[start:end][::-1] or s[start+1:end+1]==s[start+1:end+1][::-1]
    return True

s = "abc"
print(f3(s))

五、283. 移动零

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

示例 1:

输入: nums = [0,1,0,3,12]

输出: [1,3,12,0,0]

示例 2:

输入: nums = [0]

输出: [0]

python 复制代码
def test4(nums):
    j=0
    for i in range(len(nums)):
        if nums[i]:
            nums[i],nums[j]=nums[j],nums[i]
            j+=1
    return nums
nums = [0,1,0,3,12]
r=test4(nums)
print(r)
相关推荐
颜酱12 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
zone773917 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub20 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙21 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
CoovallyAIHub1 天前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
程序设计实验室1 天前
C# 扩展方法只会写 this 吗?C# 14 新语法直接把扩展方法玩出了花
c#
SparkX开源AI知识库1 天前
手摸手带你安装OpenClaw并对接飞书
算法·架构
一语07161 天前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法