python知识:用结构简化并取代嵌套循环

一、说明

        在传统的计算机语言中,有些问题解决是“硬”算,而在python中,有许多问题中,数据结构能起很大作用,这些结构的合理应用,能够节约时间。在python中,这些现象很常见。本文中,我们基本上将使用两种不同的数据结构来简化一个问题。

二、问题描述

        在一个序列中,我们将前列中某两个值的和,与后续某个元素值相等,将所有这种元素打印出来。比如:

输入序列: a=[1,2,3,4,5,6]

输出元素对: (1 2)         (1 3)         (1 4)         (1 5)         (2 3)        ( 2 4)

三、解法一

最基本的方法将包括三环。导致时间复杂度为 O(n^3)。

def suminarray(a):
    k = 0
    lis = []
    n = len(a)

    for i in range(n - 1):
        for j in range(i + 1, n):
            for l in range(n):
                if (a[i] + a[j] == a[l]):
                    lis.append((a[i], a[j]))
                    k += 1

    if (k > 0):
        return lis
    else:
        return ("NOT EXIST")

ss = [1,2,3,4,5,6,7]
tt = suminarray(ss)

四、解法二

代替第三个循环,我们可以使用数据结构来存储数组值,以便在搜索时轻松检索它们。
我们将首先使用一个列表(原始数组本身)

def suminarray(a):
    k=0
    lis=[]
    n=len(a)
    for i in range(n-1):
        for j in range(i+1,n):
            if (a[i]+a[j]) in a:
                lis.append([a[i],a[j]])
                k+=1
    if(k>0):
        return lis
    else:
        return ("NOT EXIST")

五、解法三:用字典简化案例

我们现在将使用搜索,它在搜索元素时被认为是最有效的数据结构。

def suminarray(a):
    k=0
    lis=[]
    n=len(a)
    s={i : 1 for i in a}
    print(s)
    for i in range(n-1):
        for j in range(i+1,n):
            if s.get((a[i]+a[j]),0)==1:
                lis.append([a[i],a[j]])
                k+=1
    if(k>0):
        return lis
    else:
        return ("NOT EXIST")
ss = [1,2,3,4,5,6,7]
tt = suminarray(ss)

这篇文章就到此为止。更多的关于字典的用途如下:

六、字典内置函数&方法

Python字典包含了以下内置函数:

序号函数及描述
1cmp(dict1, dict2)
比较两个字典元素。
2len(dict)
计算字典元素个数,即键的总数。
3str(dict)
输出字典可打印的字符串表示。
4type(variable)
返回输入的变量类型,如果变量是字典就返回字典类型。

Python字典包含了以下内置方法:

序号函数及描述
1dict.clear()
删除字典内所有元素
2dict.copy()
返回一个字典的浅复制
3dict.fromkeys(seq[, val])
创建一个新字典,以序列 seq 中元素做字典的键,val 为字典所有键对应的初始值
4dict.get(key, default=None)
返回指定键的值,如果值不在字典中返回default值
5dict.has_key(key)
如果键在字典dict里返回true,否则返回false
6dict.items()
以列表返回可遍历的(键, 值) 元组数组
7dict.keys()
以列表返回一个字典所有的键
8dict.setdefault(key, default=None)
和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default
9dict.update(dict2)
把字典dict2的键/值对更新到dict里
10dict.values()
以列表返回字典中的所有值
11pop(key[,default])
删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值。
12popitem()
返回并删除字典中的最后一对键和值。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

无水先生

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

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

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

打赏作者

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

抵扣说明:

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

余额充值