1.不同点:combinations方法重点在组合,permutations方法重点在排列
补充:排列和组合的区别:
排列有次序,组合没有次序
2.共同点:combinations函数和permutations函数返回的是对象地址,原因是在python3中,返回值已经不是list列表,而是iterators迭代器,所以想要使用,只要将iterator转换为list即可,还有其他的一些函数返回的也是一个对象,需要list转换,例如list(map())
返回的是对象地址
3.实例
c=0
from itertools import permutations
for i in permutations([1,2,3,4],3):
print('{}{}{}'.format(i[0],i[1],i[2]),end=' ')
c+=1
print('')
print(c)
单词一定要记住了,看到上面两个箭头的位置了吗?他们两个的单词是一毛一样的。千万不要写错,不然就会报 ‘permutations is not defined’ 错误 。 不要问我怎么知道的。。。。。。。。(/ω\)(/ω\)
4.两种方法代码比较
下面这个是我刚开始测试的代码,给我l报list不可迭代这个错误,找了老半天也不明白。。。。
后来使用了一下列表生成式就可以了。。。。。
能改成功的最重要原因就是,要将他返回的对象转换成一个列表,然后。。。。我就成功了
(▽)(▽)
import itertools
list0=[ i for i in itertools.combinations('abc',2)]
list0
import itertools
list0=[ i for i in itertools.permutations(‘abc’,2)]
list0
如果从题中看出了有排列组合这一个倾向的,大家可以使用使用这个方法哦!