【算法】算法题-20231113

这里写目录标题

一、判断是否为回文数

给定一个只包括 '(',')','{','}','[',']'的字符串 s ,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。

左括号必须以正确的顺序闭合。

每个右括号都有一个对应的相同类型的左括号。

示例 1:

输入:s = "()"

输出:true

示例2:

输入:s = "()[]{}"

输出:true

示例3:

输入:s = "(]"

输出:false

来源:力扣(LeetCode)

链接:https://leetcode.cn/problems/valid-parentheses

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

python 复制代码
import itertools
from collections import defaultdict

dic = {"(": ")", "{": "}", "[": "]", "?": "?"}


def test1(num):
    topic = ['?']
    for i in num:
        if i in dic:
            topic.append(i)
        else:
            if dic[topic.pop()] != i:
                return False
    return len(topic) == 1

num = '(()))'
res = test1(num)
print(res)

二、编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串(力口14)。

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""。

示例 1:

输入:strs = ["flower","flow","flight"]

输出:"fl"

示例 2:

输入:strs = ["dog","racecar","car"]

输出:""

解释:输入不存在公共前缀。

python 复制代码
def test2(strs):
    l = ''
    s = list(zip(*strs))
    for item in s:
        if len(set(item)) == 1:
            l += item[0]
        else:
            break
    return l
 
strs = ["flower", "flow", "flight"]
print(test2(strs))

特别注意:

python 复制代码
strs = ["flower", "flow", "flight"]
print(list(zip(*strs)))  # todo   [('f', 'f', 'f'), ('l', 'l', 'l'), ('o', 'o', 'i'), ('w', 'w', 'g')]

三、在排序数组中查找元素的第一个和最后一个位置(力扣34题)

给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。

如果数组中不存在目标值 target,返回[-1, -1]。

你必须设计并实现时间复杂度为O(log n)的算法解决此问题。

示例 1:

输入:nums = [5,7,7,8,8,10], target = 8

输出:[3,4]

示例2:

输入:nums = [5,7,7,8,8,10], target = 6

输出:[-1,-1]

示例 3:

输入:nums = [], target = 0

输出:[-1,-1]

python 复制代码
def test3(nums, target):
    if target in nums:
        return [nums.index(target), nums.index(target) + nums.count(target) - 1]
    else:
        return [-1, -1]

nums = []
target = 0
print(test3(nums, target))

四、删除排序数组中的重复项(26)

给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。

给定 nums = [0,0,1,1,1,2,2,3,3,4],

函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。

你不需要考虑数组中超出新长度后面的元素。

示例 1:

输入:nums = [1,1,2]

输出:2, nums = [1,2,_]

解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。

示例 2:

输入:nums = [0,0,1,1,1,2,2,3,3,4]

输出:5, nums = [0,1,2,3,4]

解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。

python 复制代码
def test4(nums):
    slow = 0
    fast = 0
    while fast < len(nums):
        if nums[slow] == nums[fast]:
            fast += 1
        else:
            slow += 1
            nums[slow] = nums[fast]
    return slow + 1


nums = [0, 0, 1, 1, 1, 2, 2, 3, 3, 4]
print(test4(nums))

五、计算最大的面积

给定一个长度为 n 的整数数组height。有n条垂线,第 i 条线的两个端点是(i, 0)和(i, height[i])。

找出其中的两条线,使得它们与x轴共同构成的容器可以容纳最多的水。

返回容器可以储存的最大水量。

输入:[1,8,6,2,5,4,8,3,7]

输出:49

解释:图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为49。

示例 2:

输入:height = [1,1]

输出:1

python 复制代码
def test5(nums):
    res = 0
    left = 0
    right = len(nums) - 1
    while left < right:
        pre = (right - left) * min(nums[left], nums[right])
        res = max(pre, res)
        if nums[left] <= nums[right]:
            left += 1
        else:
            right -= 1
    return res


nums = [1, 1]
print(test5(nums))
相关推荐
yyy(十一月限定版)几秒前
寒假集训4——二分排序
算法
星火开发设计几秒前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
醉颜凉11 分钟前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
qq_1777673713 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
达文汐14 分钟前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗14 分钟前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
User_芊芊君子14 分钟前
【LeetCode经典题解】搞定二叉树最近公共祖先:递归法+栈存路径法,附代码实现
算法·leetcode·职场和发展
算法_小学生16 分钟前
LeetCode 热题 100(分享最简单易懂的Python代码!)
python·算法·leetcode
执着25916 分钟前
力扣hot100 - 234、回文链表
算法·leetcode·链表
Gorgous—l18 分钟前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法