练习:四数之和



列表练习:四数之和


   CSDN“每日一练”(Python )题目

  1. 题目
  2. 代码运行效果
  3. 完整代码

练习题目

在这里插入图片描述

  看到题目与《三数之和》类似,就“偷”其代码。🤠🤠

在这里插入图片描述

  缩进太深,代码有点儿丑。🥴🥴

回首页

  target = 0, 1, 2, 3, 4 打包输出四数和的符题数组。

在这里插入图片描述

在这里插入图片描述


回首页

python完整代码
(如果从语句注释不能清楚作用,请评论区留言指教和探讨。🤝)
# coding: utf-8


def isvalid(lis, lis0):
    '''判断组合有效'''
    temp = lis0[:]
    for i in lis:
        #print(i) #调试用语句。
        if i in temp: #i在原列表置flag为True,删除原列表中的第一个i并继续遍历。
            flag = True
            temp.remove(i)
        else: #i不在原列表,置flag为False并退出遍历。
            flag = False
            break
    return flag


#input(f'\n\n{isvalid([2, 5, 9, 5], [0, 5, 9, 2, 3, 5, 4])}') #该行为调试函数功能代码。


def isremove(lis, lis2):
    '''比较两列表元素是否相同'''
    if len(lis)!=len(lis2): #列表元素不等,返回False。
        return False
    temp = lis2[:]
    for i in lis:
        if i in temp: #i在比对列表置flag为True,删除比对列表中的第一个i并继续遍历。
            flag = True
            temp.remove(i)
        else: #i不在比对列表,置flag为False并退出遍历。
            flag = False
            break
    return flag


#input(f'\n\n{isremove([2, -1, -1], [-1, 2, -1])}') #该行为调试函数功能代码。


def find_nums(target): #查找符题数组函数。
    nums_out = []
    for i in nums:
        for j in nums:
            for m in nums:
                for n in nums:
                    if i+j+m+n==target:
                        new_nums = [i, j, m, n]
                        if new_nums not in nums_out and isvalid(new_nums, nums): #组合有效且不重复,追加到输出数组。
                            flag = True
                            for k in nums_out: #判断输出数组中是否有相同元素数组,有则继续下一组合。
                                if isremove(k, new_nums):
                                    flag = False
                                    break
                            if flag is True: #组合数组不在输出数组中,追加组合数组。
                                nums_out.append(new_nums)
    return nums_out

# Main Codes
s = '''四数之和'''
nums = [1, 0, -1, 0, -2, 2]
target = 0, 1, 2, 3, 4 #预设求和值数组。
if __name__=='__main__':
    for i in target:
        print(f'\n\n{s:.^38}\n\n数组:{nums},四数和值:{i}。\n{"﹊"*21}\n\n符题组合:{find_nums(i)}\n\n{"The End":_^42}')

回首页

我的博文推荐:

推荐条件 点阅破千

参考文章:


上一篇:生成器复习:无限项斐波那契数列
下一篇:


回首页

老齐漫画头像

精品文章:

来源:老齐教室


CSDN实用技巧博文:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦幻精灵_cq

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值