搜索旋转排序数组(leetcode-033)

这道题非常简单,基本送分,之前做的代码还能用上

class Solution:
def search(self, nums: List[int], target: int) -> int:
try:
return nums.index(target)
except:
return -1

寻找峰值(leetcode-162)

它的本质是一个搜索,例如:

class Solution:
def findPeakElement(self, nums: List[int]) -> int:
for i in range(1,len(nums)-1):
if nums[i]>nums[i-1] and nums[i]>nums[i+1]:
return i
if nums[0]>nums[-1]:
return 0
else:
return len(nums)-1

寻找两个数组的中位数(leetcode 004)

本质上是一个归并排序问题。当然这个题因为两个数组有序,其实可以不用归并排序法做,只需要找到两个数组各自的中位数,然后看谁更大,对应的一个往左移一个右移

class Solution:
def findMedianSortedArrays(self, nums1: List[int], nums2: List[int]) -> float:
l=nums1+nums2
l.sort()
if len(l)%2:
return float(l[len(l)//2])
else:
return (l[len(l)//2]+l[len(l)//2-1])/2

搜寻二维数组(leetcode 240)

这个题的本质就是搜索,python使用in是很好实现的。

class Solution:
def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
for line in matrix:
if target in line:
return True
return False

实现平方根(leetcode 069)

解出一个数的平方根这个其实并不难。我是做数学建模出身的,让我们回顾到《数学建模导论》第三章3.6节的数值计算方法。假设\(\sqrt(x)=a\),那么问题也就是解方程:

\[a^2-x=0
\]

我们令\(f(a)=a^2-x\),那么可以基于牛顿法解得结果。牛顿法的迭代公式为:

\[x_{n+1}=x_{n}-\frac{f(x_n)}{f'(x_n)}
\]

这里精度要求没有特别高,迭代10次以内必然是可以求出来的。

class Solution:
def mySqrt(self, x: int) -> int:
a=1
for i in range(5):
a=a-(a*a-x)/(2*a)
return int(a)

我超,原来它要返回整数啊,那我还求什么平方根,直接遍历就好了。

移动零(leetcode 283)

这个题的话,数组元素遇到0则循环左移,记录零的个数,然后把数组末尾修改就好了。

class Solution:
def moveZeroes(self, nums: List[int]) -> None:
"""
Do not return anything, modify nums in-place instead.
"""
n=len(nums)
count=0
for i in range(n):
if nums[i]==0:
count+=1
for j in range(i+1,n):
nums[j-1]=nums[j]
for i in range(count):
nums[-1-i]=0

字符串相加(leetcode 415)

等等,这个题只是让我不能用大整数库,不能把字符转整数,没说不能用eval指令吧(笑)

那要这么说的话,我可就有活可整了

class Solution:
def addStrings(self, num1: str, num2: str) -> str:
return str(eval(num1+'+'+num2))

当然,这个题其实你要做的话就设计按位加法和进位就可以了。大家都是学习过计算机组成原理的人,串行进位加法器这个还是能够设计的。

滑动窗口最大值(leetcode 239)

这个有什么很困难的吗,一顺的往下遍历就好了啊,如果窗口比数组还长就返回自己,否则就一个个遍历啊

class Solution:
def maxSlidingWindow(self, nums: List[int], k: int) -> List[int]:
slide=[]
if k>=len(nums):
return nums
for i in range(len(nums)-k+1):
slide.append(max(nums[i:i+k]))
return slide

无重复子串(leetcode 003)

这一题就是典型的队列应用了。可以用滑动窗口法,如果后一个字符可以加进来,窗口长度+1;如果加进来重复,就队列出队

class Solution:
def lengthOfLongestSubstring(self, s: str) -> int:
i,j=0,1
count=[1]
if s[j] not in s[i:j]:
j+=1
count.append(len(s[i:j+1]))
else:
i+=1
return max(count)

最小覆盖子串(leetcode 076)

其实还是滑动窗口的思想,代码框架比较类似,用字典记录然后查找就好了

class Solution:
def minWindow(self, s: str, t: str) -> str:
n = len(s)
left = 0
need = {} # 字典记录满足条件的目标字符 char int
need_cnt = len(t) # 记录目标字符个数
l_min = 0
r_min = n + 1 # 记录最短子串右端下标 for c in t:
need[c] = need.get(c, 0) + 1 for right, c in enumerate(s): # c = s[right]
if c in need:
need[c] -= 1
if need[c] >= 0: # 减一后大于等于 0,及时更新
need_cnt -= 1 while need_cnt == 0: # 满足条件,记录答案,收缩左端点
if right - left < r_min - l_min:
r_min = right
l_min = left
if s[left] in need:
need[s[left]] += 1
if need[s[left]] > 0:
need_cnt += 1
left += 1 if r_min == n + 1: # j 没更新
return ""
else:
return s[l_min : r_min + 1]

最长子数组(leetcode 812)

这个题和最长子串其实是一回事,所以确定是考动态规划。但是动态规划这个东西一直不太会,还是要借助一下题解:

class Solution:
def findLength(self, A, B):
m, n = len(A), len(B)
ans = 0
dp = [[0 for _ in range(n + 1)] for _ in range(m + 1)]
for i in range(1, m + 1):
for j in range(1, n + 1):
if A[i - 1] == B[j - 1]:
dp[i][j] = dp[i - 1][j - 1] + 1
ans = max(ans, dp[i][j])
return ans

删除链表中的重复元素(leetcode 082)

这个问题是数据结构比较基础的东西,但是链表其实还是C可能更好实现一些,Python的面向对象版本链表总感觉差点味道。代码就参考以前C版本去改就可以了。

class Solution:
def deleteDuplicates(self, head: Optional[ListNode]) -> Optional[ListNode]:
p=[]
while head:
if head.val not in p:
p.append(head.val)
head=head.next
s=[ListNode(val=i) for i in p]
for i in range(len(s)-1):
s[i].next=s[i+1]
return s[0]

删除链表中的重复元素II(leetcode 083)

问题在于,有重复的元素都会被删除,如何统计有无重复?我想了个办法,比较烧,就是把链表转成数组处理以后再转回去。

class Solution:
def deleteDuplicates(self, head: Optional[ListNode]) -> Optional[ListNode]:
p=[]
while head.next:
p.append(head.val)
head=head.next
p.append(head.val)
r=[]
for i in p:
if p.count(i)==1:
r.append(i)
print(r)
s=[ListNode(val=i) for i in r]
for i in range(len(s)-1):
s[i].next=s[i+1]
return s[0]

datawhale-leetcode打卡 第013-025题的更多相关文章

  1. leetcode打卡

    leetcode刷题打卡 刷题链接 夸夸群 刷题记录链接 期中颜色不一样的,是刷题中遇到问题的,以后需要强化 [x] 6.1 打卡 [x] 6.2 打卡 中间因个人原因没做题,后面慢慢补上 [x] 6 ...

  2. 【LeetCode】数学(共106题)

    [2]Add Two Numbers (2018年12月23日,review) 链表的高精度加法. 题解:链表专题:https://www.cnblogs.com/zhangwanying/p/979 ...

  3. 【LeetCode】树(共94题)

    [94]Binary Tree Inorder Traversal [95]Unique Binary Search Trees II (2018年11月14日,算法群) 给了一个 n,返回结点是 1 ...

  4. LeetCode (85): Maximal Rectangle [含84题分析]

    链接: https://leetcode.com/problems/maximal-rectangle/ [描述] Given a 2D binary matrix filled with '0's ...

  5. HDU 2546 饭卡(01背包裸题)

    饭卡 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submiss ...

  6. 【LeetCode】BFS(共43题)

    [101]Symmetric Tree 判断一棵树是不是对称. 题解:直接递归判断了,感觉和bfs没有什么强联系,当然如果你一定要用queue改写的话,勉强也能算bfs. // 这个题目的重点是 比较 ...

  7. 【LeetCode】Recursion(共11题)

    链接:https://leetcode.com/tag/recursion/ 247 Strobogrammatic Number II (2019年2月22日,谷歌tag) 给了一个 n,给出长度为 ...

  8. 【LeetCode动态规划#11】打家劫舍系列题(涉及环结构和树形DP的讨论)

    打家劫舍 力扣题目链接(opens new window) 你是一个专业的小偷,计划偷窃沿街的房屋.每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻 ...

  9. 【一天一道LeetCode】#100. Same Tree(100题大关)

    一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given t ...

  10. LeetCode 136. Single Number C++ 结题报告

    136. Single Number -- Easy 解答 相同的数,XOR 等于 0,所以,将所有的数字 XOR 就可以得到只出现一次的数 class Solution { public: int ...

随机推荐

  1. Node.js Express 框架(2)

    1.读取文件并返回给客户端 res.sendFile(path):读取文件并返回给客户端,适合静态页面 app.get("/",function(req,res){ res.sen ...

  2. 知乎 微软当年的 J++ 究竟是什么?为什么 Sun 要告它? zz

    https://www.zhihu.com/question/22814456 考个古

  3. 基于Java SpringBoot的音乐网站与分享平台

    @ 目录 摘要 1. 研究背景 2.研究内容 3.系统功能 3.1前台首页功能模块 3.2在线听歌功能模块 3.3后台登录功能模块 3.4在线听歌管理模块 4.部分功能代码实现 5.源码分享(免费获取 ...

  4. jenkins异常 -- active (exited),无法启动

    一.问题描述 1.无法启动 systemctl start jenkins 没有反应,没有输出报错 2.查询状态 systemctl status jenkins 3.jenkins拒绝访问 二.解决 ...

  5. Qt/C++音视频开发67-保存裸流加入sps/pps信息/支持264/265裸流/转码保存/拉流推流

    一.前言 音视频组件除了支持保存MP4文件外,同时还支持保存裸流即264/265文件,以及解码后最原始的yuv文件.在实际使用过程中,会发现部分视频文件保存的裸流文件,并不能直接用播放器播放,查阅资料 ...

  6. Qt音视频开发36-USB摄像头解码qcamera方案

    一.前言 除了监控专用的摄像头以外,有一些应用场景用的还是USB摄像头,甚至还有一些单片机或者开发板上用的CMOS摄像头,而Qt在嵌入式领域应用相当广,所以用Qt来读取加载显示USB摄像头和CMOS摄 ...

  7. [转]java调用python脚本以及通过Process.waitFor()直接调用python模块返回错误代码1的一种解决办法

    常见的java调用python脚本方式 通过jython提供的类库实现 通过Runtime.getRuntime()开启进程来执行脚本文件 通过jython提供的类库实现 通过jython实现的话,我 ...

  8. Python开发环境的构建:使用Anaconda与Pycharm

    Anaconda是一个科学计算环境,当在电脑上安装好Anaconda3以后,就相当于安装好了Python,还有一些常用的库,如numpy,scrip,matplotlib等库. (如果你这里没有安装a ...

  9. 移动端弱网优化专题(十四):携程APP移动网络优化实践(弱网识别篇)

    本文由携程技术团队Aaron分享,原题"干货 | 携程弱网识别技术探索",下文进行了排版和内容优化. 1.引言 网络优化一直是移动互联网时代的热议话题,弱网识别作为移动端弱网优化的 ...

  10. G1原理—6.G1垃圾回收过程之Full GC

    大纲 1.FGC的一些前置处理 2.FGC的整体流程 3.传统FGC只能串行化 + G1的FGC可以并发化 4.并行化FGC之并行标记 + 任务窃取 5.并行化FGC之跨分区压缩 + 避免对象跨分区 ...