免费注册 查看新帖 |

Chinaunix

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

一个涉及到算法的问题,怎么解决? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-12-04 11:55 |只看该作者 |倒序浏览
比如根据用户输入:
[s,d,j],[1,2,3],[1,3]
输出下面结果:
s 1 1
s 1 3
s 2 1
s 2 3
s 3 1
s 3 3
d 1 1
d 1 3
d 2 1
d 2 3
等等
下面就不列举了。


现在问题是:
用户输入[]的数量不确定
[]里面的元素数量不确定
在这种情况下,打印出来根据以上规律 所有可能的组合
最好使用python 其他语言能实现也行。上面例子中严格来说字符应该加引号的,本人没有加,这个不是主要问题。
这个怎么实现?本人想了若干个小时 都没有想到解决办法?

论坛徽章:
9
2015亚冠之阿尔纳斯尔
日期:2015-09-10 16:21:162015亚冠之塔什干火车头
日期:2015-07-01 16:23:022015年亚洲杯之巴勒斯坦
日期:2015-04-20 17:19:46子鼠
日期:2014-11-13 09:51:26未羊
日期:2014-08-28 18:13:36技术图书徽章
日期:2014-02-21 09:30:15酉鸡
日期:2014-01-14 11:12:49天蝎座
日期:2013-12-09 17:56:53平安夜徽章
日期:2015-12-26 00:06:30
2 [报告]
发表于 2014-12-04 11:58 |只看该作者
将用户输入存到一个list,然后遍历list里所有list元素的组合?

论坛徽章:
0
3 [报告]
发表于 2014-12-04 12:00 |只看该作者
回复 2# HH106

这个题不是考验坛友的,是求助的,我也不知道答案。其实看着简单,我实际解决了,感觉一点也不简单。还是写代码自己试试能不能实现吧?


   

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
4 [报告]
发表于 2014-12-04 12:03 |只看该作者
先来个shell的吧
  1. echo {s,d,j}{1,2,3}{1,3} | xargs -n1 | awk -F '' 'NF+=0'
复制代码
Python里也有现成的模块, itertools

论坛徽章:
0
5 [报告]
发表于 2014-12-04 12:11 |只看该作者
回复 4# reyleon

itertools这个模块我知道。
真是awk之神阿,真是神了,能够完美解决问题。
   

论坛徽章:
46
2015小元宵徽章
日期:2015-03-06 15:58:18羊年新春福章
日期:2015-04-14 10:37:422015年亚洲杯之阿曼
日期:2015-04-14 10:41:50NBA常规赛纪念章
日期:2015-05-04 22:32:03NBA季后赛大富翁
日期:2015-05-04 22:34:11菠菜明灯
日期:2015-05-04 22:35:49新奥尔良黄蜂
日期:2015-05-04 22:49:2315-16赛季CBA联赛之广夏
日期:2015-12-11 15:02:342015年亚洲杯之巴勒斯坦
日期:2015-03-04 19:56:562015年亚洲杯之阿联酋
日期:2015-03-04 11:19:04休斯顿火箭
日期:2015-03-02 16:32:11纽约尼克斯
日期:2015-03-02 16:09:04
6 [报告]
发表于 2014-12-04 14:00 |只看该作者
C语言的for循环就可以解决

论坛徽章:
0
7 [报告]
发表于 2014-12-04 14:21 |只看该作者
回复 6# super皮波

怎么解决?写出来,参考一下。

   

论坛徽章:
0
8 [报告]
发表于 2014-12-04 14:21 |只看该作者
回复 4# reyleon

请问能不用shell还有python自带的模块解决吗?

   

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
9 [报告]
发表于 2014-12-04 15:21 |只看该作者
回复 8# 漠北病树
  1. >>>
  2. >>> import itertools
  3. >>> l = [ ['s','d','j'],['1','2','3'],['1','3'] ]

  4. >>> for r in itertools.product(*l):
  5.         print ' '.join(r)

  6.        
  7. s 1 1
  8. s 1 3
  9. s 2 1
  10. s 2 3
  11. s 3 1
  12. s 3 3
  13. d 1 1
  14. d 1 3
  15. d 2 1
  16. d 2 3
  17. d 3 1
  18. d 3 3
  19. j 1 1
  20. j 1 3
  21. j 2 1
  22. j 2 3
  23. j 3 1
  24. j 3 3
  25. >>>
复制代码
别人写的, 如果对Python感兴趣, 欢迎入群讨论: 49528098


{:3_189:}

论坛徽章:
0
10 [报告]
发表于 2014-12-04 15:48 |只看该作者
本帖最后由 huangxiaohen 于 2014-12-04 15:50 编辑

傻傻没看懂,这不就是个for循环的事么....说错莫怪。。
  1. a = ["a","b","c"]
  2. b = [1,2,3]
  3. c = [1,3]

  4. print [(s,i,j) for s in a for i in b for j in c]
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP