免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 8170 | 回复: 25
打印 上一主题 下一主题

python学习日记--数字组合 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-18 17:47 |只看该作者 |倒序浏览
题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
_198:}
#/usr/bin/python
#Name :sun

for i in range(1,5):
    for j in range(1,5):
        for k in range(1,5):
            if( i != k ) and (i != j) and (j != k):
                print i,j,k

请指点

论坛徽章:
0
2 [报告]
发表于 2010-06-18 17:50 |只看该作者

学习python是这样学习吗?

论坛徽章:
0
3 [报告]
发表于 2010-06-18 18:00 |只看该作者
http://bbs.chinaunix.net/thread-1668860-1-1.html

还是看看置顶帖吧。里面有一些教程。

你问的这个问题实际上需要知道的是算法,具体实现,用python和用C其实没啥区别。

论坛徽章:
0
4 [报告]
发表于 2010-06-18 18:16 |只看该作者

论坛徽章:
0
5 [报告]
发表于 2010-06-19 03:23 |只看该作者
老用python去写多重循环也太没追求了。。。
  1. list(itertools.permutations("1234",3))
复制代码

论坛徽章:
0
6 [报告]
发表于 2010-06-19 08:31 |只看该作者
源码里抄的,permutations的实现跟这个一样  只不过用的是c。
  1. def permutations(iterable, r=None):
  2.     'permutations(range(3), 2) --> (0,1) (0,2) (1,0) (1,2) (2,0) (2,1)'
  3.     pool = tuple(iterable)
  4.     n = len(pool)
  5.     r = n if r is None else r
  6.     indices = range(n)
  7.     cycles = range(n-r+1, n+1)[::-1]
  8.     yield tuple(pool[i] for i in indices[:r])
  9.     while n:
  10.         for i in reversed(range(r)):
  11.             cycles[i] -= 1
  12.             if cycles[i] == 0:
  13.                 indices[i:] = indices[i+1:] + indices[i:i+1]
  14.                 cycles[i] = n - i
  15.             else:
  16.                 j = cycles[i]
  17.                 indices[i], indices[-j] = indices[-j], indices[i]
  18.                 yield tuple(pool[i] for i in indices[:r])
  19.                 break
  20.         else:
  21.             return
复制代码

论坛徽章:
0
7 [报告]
发表于 2010-06-20 08:00 |只看该作者
这种问题也太没意思了......

论坛徽章:
0
8 [报告]
发表于 2010-06-20 08:08 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
9 [报告]
发表于 2010-06-20 10:56 |只看该作者
这种问题也太没意思了......
2gua 发表于 2010-06-20 08:00

扯淡   你写个permutations实现出来看看?

论坛徽章:
0
10 [报告]
发表于 2010-06-20 11:47 |只看该作者
扯淡   你写个permutations实现出来看看?
luffy.deng 发表于 2010-06-20 10:56



    我说permutations吗?你扯自己的淡去吧!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP