zoukankan      html  css  js  c++  java
  • Python排列组合

    product 笛卡尔积  (有放回抽样排列)

    permutations 排列  (不放回抽样排列)

    combinations 组合,没有重复  (不放回抽样组合)

    combinations_with_replacement 组合,有重复  (有放回抽样组合)

    >>> import itertools
    >>> for i in itertools.product('ABCD', repeat = 2):
    ...     print(i)
    ... 
    ('A', 'A') ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'A') ('B', 'B') ('B', 'C') ('B', 'D') ('C', 'A') ('C', 'B') ('C', 'C') ('C', 'D') ('D', 'A') ('D', 'B') ('D', 'C') ('D', 'D')
    >>> for i in itertools.permutations('ABCD', 2):
    ...     print(i)
    ... 
    ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'A') ('B', 'C') ('B', 'D') ('C', 'A') ('C', 'B') ('C', 'D') ('D', 'A') ('D', 'B') ('D', 'C')
    >>> for i in itertools.combinations('ABCD', 2):
    ...     print(i)
    ... 
    ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'C') ('B', 'D') ('C', 'D')
    >>> for i in itertools.combinations_with_replacement('ABCD', 2):
    ...     print(i)
    ... 
    ('A', 'A') ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'B') ('B', 'C') ('B', 'D') ('C', 'C') ('C', 'D') ('D', 'D')>>> import itertools
    >>> for i in itertools.product('ABCD', repeat = 2):
    ...     print(i)
    ... 
    ('A', 'A') ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'A') ('B', 'B') ('B', 'C') ('B', 'D') ('C', 'A') ('C', 'B') ('C', 'C') ('C', 'D') ('D', 'A') ('D', 'B') ('D', 'C') ('D', 'D')
    >>> for i in itertools.permutations('ABCD', 2):
    ...     print(i)
    ... 
    ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'A') ('B', 'C') ('B', 'D') ('C', 'A') ('C', 'B') ('C', 'D') ('D', 'A') ('D', 'B') ('D', 'C')
    >>> for i in itertools.combinations('ABCD', 2):
    ...     print(i)
    ... 
    ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'C') ('B', 'D') ('C', 'D')
    >>> for i in itertools.combinations_with_replacement('ABCD', 2):
    ...     print(i)
    ... 
    ('A', 'A') ('A', 'B') ('A', 'C') ('A', 'D') ('B', 'B') ('B', 'C') ('B', 'D') ('C', 'C') ('C', 'D') ('D', 'D')

    combinations和permutations返回的是对象地址,原因是在python3里面,返回值已经不再是list,而是iterators(迭代器), 所以想要使用,只用将iterator 转换成list 即可

  • 相关阅读:
    算法题---最长公共前缀
    算法练习题---罗马数字转int
    算法练习题---原地删除数组元素
    获取当前服务的IP和端口号
    算法练习题---回文数
    Java数学表示式解析工具- jeval
    Redis的安装与部署
    Centos开机自启动redis
    Java 7 的 7 个新的 “酷” 特性
    java7新特性——使用ThreadLocalRandom产生并发随机数
  • 原文地址:https://www.cnblogs.com/413xiaol/p/9074358.html
Copyright © 2011-2022 走看看