力扣16~20题

题16(中等):

思路:

双指针法,和15题差不多,就是要排除了,如果total<target则排除了更小的(left右移),如果total>target则排除了更大的(right左移)

python代码:

复制代码
class Solution:
    def threeSumClosest(self, nums: List[int], target: int) -> int:
        nums.sort()
        sum=nums[0]+nums[1]+nums[2]
        for i in range(len(nums)):
            if i>0 and nums[i]==nums[i-1]:
                continue
            left = i + 1
            right = len(nums) - 1
            while left < right:
                total=nums[i]+nums[left]+nums[right]
                if abs(target-total)<abs(target-sum):
                    sum=total
                if total<target:
                    left+=1
                elif total>target:
                    right-=1
                else:
                    return target
        return sum

题17(中等):

思路:

枚举列出来就好了,能过就行,虽然时间复杂度有点

python代码:

class Solution:

def letterCombinations(self, digits: str) -> Liststr:

if digits=='':

return \[\]

btn_json={

'1':'',

'2':'abc',

'3':'def',

'4':'ghi',

'5':'jkl',

'6':'mno',

'7':'pqrs',

'8':'tuv',

'9':'wxyz',

}

res_list=''

for i in digits:

res=btn_jsoni

tmp_list=res_list

res_list=n+j for n in tmp_list for j in res

return res_list

题18(中等):

思路:

两数和,三数和,三数接近,这几题好玩吧,没尽兴就又来了一个4数和,一样的

python代码

class Solution:

def fourSum(self, nums: Listint, target: int) -> ListList\[int]:

nums.sort()

res_list=\[\]

for i in range(len(nums)):

if i>0 and numsi==numsi-1:

continue

tmp_target=target-numsi

for j in range(i+1,len(nums)):

if j>i+1 and numsj==numsj-1:

continue

left=j+1

right=len(nums)-1

while left<right:

total=numsleft+numsright+numsj

if total==tmp_target:

res_list.append(nums\[i,numsj,numsleft,numsright])

while left<right and numsleft==numsleft+1:

left+=1

while left<right and numsright==numsright-1:

right-=1

left+=1

right-=1

elif total<tmp_target:

left+=1

else:

right-=1

return res_list

题19(中等):

思路:

这个用c应该比较容易理解

python代码:

Definition for singly-linked list.

class ListNode:

def init(self, val=0, next=None):

self.val = val

self.next = next

class Solution:

def removeNthFromEnd(self, head: OptionalListNode, n: int) -> OptionalListNode:

n_len=1

p=head

while 1:

if p.next!=None:

n_len+=1

p=p.next

else:

break

pos=n_len-n

p=head

if pos==0:

head=head.next

return head

for i in range(pos-1):

p=p.next

p.next=p.next.next

return head

题20(简单):

思路:

这个就是金典的栈的运用啊,我之前还有一个文章是表达式的转换来着

python代码:

class Solution:

def isValid(self, s: str) -> bool:

s_stack=\[\]

for i in s:

if i=='(' or i=='{' or i=='[':

s_stack.append(i)

elif i==')':

if len(s_stack)!=0 and s_stack-1=='(':

s_stack.pop()

else:

return False

elif i == '}':

if len(s_stack)!=0 and s_stack-1 == '{':

s_stack.pop()

else:

return False

elif i == ']':

if len(s_stack)!=0 and s_stack-1 == '[':

s_stack.pop()

else:

return False

if len(s_stack)==0:

return True

else:

return False

相关推荐
吴可可1231 分钟前
AutoCAD2016二次开发环境配置指南
算法·机器学习
一条大祥脚4 分钟前
ABC461 枚举|扫描线|动态前缀和|数论|dfs枚举子集
算法·深度优先
计算机安禾7 分钟前
【数据库系统原理】第14篇:关系模式的语义约束:函数依赖的公理系统与闭包计算
人工智能·算法·机器学习
量化君也9 分钟前
快速入门量化交易都要学些什么?
大数据·人工智能·python·算法·金融
AbandonForce19 分钟前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
炸薯条!32 分钟前
二叉树的链式表示(2)
java·数据结构·算法
Tairitsu_H35 分钟前
[LC优选算法#2] 滑动窗口 | 长度最小的子数组 | 无重复字符的最长子串 | 最大连续1的个数
算法
小欣加油37 分钟前
leetcode3689最大子数组总值I
c++·算法·leetcode·职场和发展·贪心算法
下午写HelloWorld44 分钟前
【概念与应用】轻量级加密算法LEA、动态脱敏算法DDA、零知识证明ZKP和优化协同交互协议OCIP
算法·区块链·密码学·安全架构·零知识证明
飞舞哲1 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab