zoukankan      html  css  js  c++  java
  • Python的Set和List的性能比较 + 两者之间的转换

    1.能用set 不用list

    ~$ python -m timeit -n 1000 "[x for x in range(1000) if x in range(500, 1500)]"

    1000 loops, best of 3: 28.2 msec per loop

    ~$ python -m timeit -n 1000 "set(range(1000)).intersection(range(500, 1500))"

    1000 loops, best of 3: 120 usec per loop

    List 大概用了Set的225倍的时间。List转Set基本用不了什么时间,所以如果有需要求(集合,列表等)的并集和交集的时候,最好使用Set。

     

    2.

    set转成list方法如下:                                                     list转成set方法如下:
    s = set('12342212')                                                      l = ['12342212']
    print s    # set(['1', '3', '2', '4'])                                    s = set(l[0])
    l = list(s)                                                                          print s    # set(['1', '3', '2', '4'])
    l.sort()    # 排序                                                               m = ['11','22','33','44','11','22']
    print l    # ['1', '2', '3', '4']                                              print set(m)    # set(['11', '33', '44', '22'])

     

    可见set和lsit可以自由转换,在删除list中多个/海量重复元素时,可以先转换成set,然后再转回list并排序(set没有排序)。此种方法不仅方便且效率较高。

  • 相关阅读:
    Metinfo 5.x 管理员密码重置漏洞
    【CVE-2018-11116】openwrt rpcd 配置文件错误导致访问控制失效
    openwrt-rpcd服务ACL配置错误风险分析
    黑客基础知识
    渗透测试(漏洞利用)
    Niagara物联网框架机制二(笔记)
    基于kali linux无线网络渗透测试
    渗透测试(漏洞扫描)
    Workbench热水泵系统
    Niagara物联网框架机制一(笔记)
  • 原文地址:https://www.cnblogs.com/chaoren399/p/4858263.html
Copyright © 2011-2022 走看看