练习:三数之和



三数之和


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

  1. 题目
  2. 我的想法
  3. 代码运行效果
  4. 完整代码

练习题目

在这里插入图片描述


回首页

我的想法


  我起初设想,是列出所有sum()为0的组合,剔除不合规和重复的就好。实现起来简单。🤗🤗🤗

  但,“想法美好而现实残酷”——我怎么也码不出判断合规和元素相同链表的代码。😭😭直到想了几天之后的今天,才码出了两个判断方法,得以实现题目要求。但,还可以优化代码,把判断链表元素相同放到列出合规组合后面,就少判断不合规的组合,类似“冒泡排序”,但我今天就是写不出来了。😭😭

回首页

代码运行效果

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


回首页

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])}') #该行为调试函数功能代码。



s = '''三数之和'''
blank = ' '
line = '﹊'*21
nums = [-1, 0, 1, 2, -1, -4]
nums_out = []
for i in nums:
    for j in nums:
        for k in nums:
            if i+j+k==0:
                new_nums = [i, j, k]
                if new_nums not in nums_out and isvalid(new_nums, nums): #组合有效且不重复,追加到输出数组。
                    flag = True
                    for m in nums_out: #判断输出数组中是否有相同元素数组,有则继续下一组合。
                        if isremove(m, new_nums):
                            flag = False
                            break
                    if flag is True: #组合数组不在输出数组中,追加组合数组。
                        nums_out.append(new_nums)
input(f'\n\n{s:.^38}\n\n数组:{nums}\n{line}\n\n输出:{nums_out}\n\n{"The End":_^42}')

回首页

我的博文推荐:

推荐条件 点阅破千

参考文章:


上一篇:斐波那契数列的递归实现和for实现
下一篇:


回首页

老齐漫画头像

精品文章:

来源:老齐教室


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、付费专栏及课程。

余额充值