• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程问答 > 求多数组的排列组合算法

求多数组的排列组合算法

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-07

佚名通过本文主要向大家介绍了数组全排列算法,数组排列组合,js数组排列组合,数组降序排列,数组升序排列等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题:求多数组的排列组合算法
描述:

有多个数组, 比如:
{a,b,c,d}
{1,2}
{g}
{q,w,e}
想分别从每个数组中取出一个值, 然后组合.({a,1,g,q} {a,2,g,q}... ...)
怎么样才能把所有的情况都组合起来呢?


解决方案1:

记录每个数组的当前元素下标。
问题中的例子为例:
[0, 0, 0, 0]
[0, 0, 0, 1]
[0, 0, 0, 2]
最后一个走到头了,于是他的前一个加1,自己自觉退到0,
这时发现{g}也到头了,于是他的前一个(假设为i)加1,i之后的都统统清零:
[0, 1, 0, 0]
[0, 1, 0, 1]
...
直到第一个数也走到头。

解决方案2:

我知道你问的是java的,不过我给个python的,python 比较方便 嘿嘿,java的原理是一样的

L1=['a','b','c','d']
L2=['1','2']
L3=['g']
L4=['q','w','e']
list = [[i,j,k,p] for i in L1 for j in L2 for k in L3 for p in L4]

补充回答:不确定几个list,不确定list多长的时候

#把取来的数组合成一个大list,然后再一行代码就没有然后了
s=[ ['a','b','c','d'], ['1','2'], ['g'],['q','w','e'] ]
list = list(itertools.product(*s))

解决方案3:

递归

public List<String> permutation(List<String> inputList){
    List<String> resList = new ArrayList<>();
    permutationInt(inputList, resList, 0, 
            new char[inputList.size()]);
    return resList;
}



private void permutationInt(List<String> inputList, List<String> resList,
        int ind, char[] arr) {
    if(ind == inputList.size()){
        resList.add(new String(arr));
        return;
    }

    for(char c: inputList.get(ind).toCharArray()){
        arr[ind] = c;
        permutationInt(inputList, resList, ind + 1, arr);
    } 
}


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 求算法,重新排列数组
  • 求多数组的排列组合算法

相关文章

  • 2017-06-07 关于一个消息传递的ESB项目
  • 2017-06-07 (shell)oracle错误ERRORORA-12162
  • 2017-06-07 一般防盗链设置多久才能生效呢?
  • 2017-06-07 redis或memcache缓存操作类封装有哪些点需要注意?
  • 2017-06-07 云存储绑定自定义域名是如何实现的?
  • 2017-06-07 周公解梦梦到龙广州梦龙公司的那种掌上小玩具是用什么开发的
  • 2017-06-07 qiniucom域名再次出现问题,什么时候能彻底解决呢
  • 2017-06-07 利用python的scrapy框架中的css选择器获取不到元素内容
  • 2017-06-07 md5校验工具下载七牛MD5下载不一致
  • 2017-06-07 python爬虫python怎么获取网址

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • hibernate和中间件的问题
    • jBPM能否用来开发有几十万用户的大型工作流网站?
    • 七牛云存储七牛云现在支持HTTP2吗
    • pythonlist转dict
    • 百度移动搜索IndexPage提示:链接指向非网页文件indexhtml
    • 一个服务器的redis的dumprdb文件放到另外一个服务器,无法读取了!
    • php问题:代理ip地址如何提取出来
    • Python'gbk'codeccan'tencodecharacteru'\xbb'
    • XPath匹配时如何去掉空格换行只保留文本内容
    • a,b,c=data

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有