一、三数之和:LeetCode 15

给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组。

注意:答案中不可以包含重复的三元组。

例如, 给定数组 nums = [-1, 0, 1, 2, -1, -4],

满足要求的三元组集合为:
[
[-1, 0, 1],
[-1, -1, 2]
]

解题代码一:

class Solution:
def threeSum(self, nums):
"""
:type nums: List[int]
:rtype: List[List[int]]
"""
result=[]
nums.sort()
for i in range(len(nums)-2):
#下标i表示三个数中的第一个数
if i>0 and nums[i]==nums[i-1]:#遇到重复的数就直接跳过,避免重复计算三元组
continue
#下标j表示三个数中的第二个,从i+1开始递增;下标k表示三个数中的第三个,从len(nums)-1递减
j,k=i+1,len(nums)-1
while j<k:
sum0=nums[i]+nums[j]+nums[k]
if sum0<0:
j+=1
elif sum0>0:
k-=1
else:
result.append([nums[i],nums[j],nums[k]])
#如果此时j和后面的数重复,k和前面的数重复记得要直接跳过
while j<k and nums[j+1]==nums[j]:
j+=1
while j<k and nums[k-1]==nums[k]:
k-=1
j+=1
k-=1
return result

解题代码二:更通用,适用于Nsum

class Solution:
def threeSum(self, nums):
"""
:type nums: List[int]
:rtype: List[List[int]]
""" # method 2:通用方法 nums.sort()
results=[]
self.findNSum(nums,0,3,[],results)
return results def findNSum(self,nums,target,N,result,results):
if N<2 or len(nums)<N or target<nums[0]*N or target>nums[-1]*N:
return
if N==2:
j,k=0,len(nums)-1
while j<k:
s=nums[j]+nums[k]
if s<target:
j+=1
elif s>target:
k-=1
else:
results.append(result+[nums[j],nums[k]])
while j<k and nums[j+1]==nums[j]:
j+=1
while j<k and nums[k-1]==nums[k]:
k-=1
j+=1
k-=1
else:
# 共有len(nums)-N+1个N元组
for i in range(len(nums)-N+1):
if i==0 or (i>0 and nums[i-1]!=nums[i]):
self.findNSum(nums[i+1:],target-nums[i],N-1,result+[nums[i]],results)
return

二、四数之和 LeetCode

给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值与 target 相等?找出所有满足条件且不重复的四元组。

注意:

答案中不可以包含重复的四元组。

示例:

给定数组 nums = [1, 0, -1, 0, -2, 2],和 target = 0。

满足要求的四元组集合为:
[
[-1, 0, 0, 1],
[-2, -1, 1, 2],
[-2, 0, 0, 2]
]

解题代码:(通用,适合于NSum)

class Solution:
def fourSum(self, nums, target):
"""
:type nums: List[int]
:type target: int
:rtype: List[List[int]]
"""
nums.sort()
results=[]
self.findNSum(nums,target,4,[],results)
return results def findNSum(self,nums,target,N,result,results):
if N<2 or len(nums)<N or target<nums[0]*N or target>nums[-1]*N:
return
if N==2:
j,k=0,len(nums)-1
while j<k:
s=nums[j]+nums[k]
if s<target:
j+=1
elif s>target:
k-=1
else:
results.append(result+[nums[j],nums[k]])
while j<k and nums[j+1]==nums[j]:
j+=1
while j<k and nums[k-1]==nums[k]:
k-=1
j+=1
k-=1
else:
# 共有len(nums)-N+1个N元组
for i in range(len(nums)-N+1):
if i==0 or (i>0 and nums[i-1]!=nums[i]):
self.findNSum(nums[i+1:],target-nums[i],N-1,result+[nums[i]],results)
return

三、牛客网 求和

链接:https://www.nowcoder.com/questionTerminal/11cc498832db489786f8a03c3b67d02c
来源:牛客网

输入两个整数 n 和 m,从数列1,2,3.......n 中随意取几个数,使其和等于 m ,要求将其中所有的可能组合列出来

输入描述:
每个测试输入包含2个整数,n和m
输出描述:
按每个组合的字典序排列输出,每行输出一种组合
示例1

输入

5 5

输出

1 4
2 3
5

解法一:改造NSum

n, m = [int(x) for x in input().split()]

def findNSum(nums, target, N, result, results):
if N < 2 or len(nums) < N or target < nums[0]*N or target > nums[-1]*N:
return
if N == 2:
j, k = 0, len(nums)-1
while j < k:
s = nums[j]+nums[k]
if s < target:
j += 1
elif s > target:
k -= 1
else:
results.append(result+[nums[j], nums[k]])
while j < k and nums[j+1] == nums[j]:
j += 1
while j < k and nums[k-1] == nums[k]:
k -= 1
j += 1
k -= 1
else:
# 共有len(nums)-N+1个N元组
for i in range(len(nums)-N+1):
if i == 0 or (i > 0 and nums[i-1] != nums[i]):
findNSum(nums[i+1:], target-nums[i],
N-1, result+[nums[i]], results)
return results = []
nums = range(1, n+1)
for i in range(1, n+1):
if i == m:
results.append([i])
for i in range(2, n+1):
findNSum(nums, m, i, [], results)
res=sorted(results)
for arr in res:
for i in range(len(arr)):
if i==len(arr)-1:
print(arr[i])
else:
print(arr[i],end=' ')

解法三:DFS 递归

n,m=[int(x) for x in input().split()]

def dfs(res,s,temp,n,m,k):
if s==m:
if temp not in res:
res.append(temp)
for i in range(len(temp)):
if i!=len(temp)-1:
print(temp[i],end=' ')
else:
print(temp[i])
if k>n:
return
for i in range(k,n+1):
if s+i>m:
break
else:
dfs(res,s+i,temp+[i],n,m,i+1)
res=[]
dfs(res,0,[],n,m,1)

算法题 21 findNSum (好未来,LeetCode,牛客网)的更多相关文章

  1. 算法题16 贪吃的小Q 牛客网 腾讯笔试题

    算法题16 贪吃的小Q 牛客网 腾讯笔试题 题目: 链接:https://www.nowcoder.com/questionTerminal/d732267e73ce4918b61d9e3d0ddd9 ...

  2. 算法题 19 二叉平衡树检查 牛客网 CC150

    算法题 19 二叉平衡树检查 牛客网 CC150 实现一个函数,检查二叉树是否平衡,平衡的定义如下,对于树中的任意一个结点,其两颗子树的高度差不超过1. 给定指向树根结点的指针TreeNode* ro ...

  3. 牛客网《BAT面试算法精品课》学习笔记

    目录 牛客网<BAT面试算法精品课>学习笔记 牛客网<BAT面试算法精品课>笔记一:排序 牛客网<BAT面试算法精品课>笔记二:字符串 牛客网<BAT面试算法 ...

  4. 牛客网Java刷题知识点之垃圾回收算法过程、哪些内存需要回收、被标记需要清除对象的自我救赎、对象将根据存活的时间被分为:年轻代、年老代(Old Generation)、永久代、垃圾回收器的分类

    不多说,直接上干货! 首先,大家要搞清楚,java里的内存是怎么分配的.详细见 牛客网Java刷题知识点之内存的划分(寄存器.本地方法区.方法区.栈内存和堆内存) 哪些内存需要回收 其实,一般是对堆内 ...

  5. 算法题14 小Q歌单,牛客网,腾讯笔试题

    算法题14 小Q歌单,牛客网,腾讯笔试题 题目: 小Q有X首长度为A的不同的歌和Y首长度为B的不同的歌,现在小Q想用这些歌组成一个总长度正好为K的歌单,每首歌最多只能在歌单中出现一次,在不考虑歌单内歌 ...

  6. 算法题 18 像素翻转 牛客网 CC150

    算法题 18 像素翻转 牛客网 CC150_P114 题目描述 有一副由NxN矩阵表示的图像,这里每个像素用一个int表示,请编写一个算法,在不占用额外内存空间的情况下(即不使用缓存矩阵),将图像顺时 ...

  7. [牛客网 -leetcode在线编程 -01] max-points-on-a-line -穷举

    题目及题目来源 链接:https://www.nowcoder.com/questionTerminal/bfc691e0100441cdb8ec153f32540be2 来源:牛客网 首页 > ...

  8. 牛客网 2018年东北农业大学春季校赛 L题 wyh的天鹅

    链接:https://www.nowcoder.com/acm/contest/93/L来源:牛客网 时间限制:C/C++ 3秒,其他语言6秒空间限制:C/C++ 262144K,其他语言524288 ...

  9. 牛客网刷题(纯java题型 31~60题)

    牛客网刷题(纯java题型 31~60题) 重写Override应该满足"三同一大一小"三同:方法名相同,参数列表相同,返回值相同或者子类的返回值是父类的子类(这一点是经过验证的) ...

随机推荐

  1. k8s入门

    一个目标:容器操作:两地三中心:四层服务发现:五种Pod共享资源:六个CNI常用插件:七层负载均衡:八种隔离维度:九个网络模型原则:十类IP地址:百级产品线:千级物理机:万级容器:相如无亿,K8s有亿 ...

  2. Android开发 获取当前activity的屏幕截图(转载)

    首先通过下面的函数获取Bitmap格式的屏幕截图: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 pu ...

  3. php判断今日是本月的第几个星期几

    php判断今日是本月的第几个星期几 php中有一个非常强悍的系统函数date()函数.巧妙的利用他可以实现显示任意我们需要的时间.比如今天遇到个需要是要判断今天是本月的第几个星期几,这里就不讨论这种说 ...

  4. GAN网络

    http://www.sohu.com/a/130252639_473283 高分辨率图像重建 https://zhuanlan.zhihu.com/p/25201511 生成式对抗网络GAN有哪些最 ...

  5. Windows编程中回调函数的使用心得(MFC篇)

    回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数.回调函数不是由该函数的实现方直接调用,而是在特定 ...

  6. 红黑树red-black tree

    书籍:<算法导论>第13章 红黑树性质:1. 每个节点要么red要么black.2. 根节点是black节点.3. 叶子节点是black节点.4. red节点的左右儿子节点都是black节 ...

  7. java拆装箱(转)

    转载:http://www.cnblogs.com/dolphin0520/p/3780005.html 深入剖析Java中的装箱和拆箱 自动装箱和拆箱问题是Java中一个老生常谈的问题了,今天我们就 ...

  8. iOS开发之 -- 判断tableview/scrollview的滑动方法,及导航栏渐变的实现代码

    开发的过程中,肯定会用到在视图想上滑动的时候,在导航处做一些操作,比如向上滑动的时候,做个动画,出现一个搜索框,或者其他的操作,那么我们怎么来判断它的滑动方向呢? 首先我们应该知道tableview继 ...

  9. AndroidManifest.xml文件详解(activity)(五)

    android:taskAffinity 这个属性用于跟Activity有亲缘关系的任务.带有相同亲缘关系的Activity,在概念上是属于相同任务的(从用户的角度看,它们是属于同一应用程序的).任务 ...

  10. Dapper的语法应用

    (1)返回某个整型或字符串类型的字段 public string GetSupplierCodeById(int Id) { using( var conn=DbFactory.CreateConne ...