面试题:编程实现全排列,选择排列java算法小谈

系统 2536 0

实现起来有很多方法,下面介绍一个代码最简单的,但理解起来稍微费点劲的算法。。



    import java.util.ArrayList;   
import java.util.Arrays;   
import java.util.List;   
   

public class FullSort {   
    //将NUM设置为待排列数组的长度即实现选择排列   
    private static int NUM = 3;   
   
    /**
     * 递归算法:将数据分为两部分,递归将数据从左侧移右侧实现选择排列
     *
     * @param datas
     * @param target
     */   
    private static void sort(List datas, List target) {   
        if (target.size() == NUM) {   
            for (Object obj : target)   
                System.out.print(obj);   
            System.out.println();   
            return;   
        }   
        for (int i = 0; i < datas.size(); i++) {   
            List newDatas = new ArrayList(datas);   
            List newTarget = new ArrayList(target);   
            newTarget.add(newDatas.get(i));   
            newDatas.remove(i);   
            sort(newDatas, newTarget);   
        }   
    }   
   
    public static void main(String[] args) {   
        String[] datas = new String[] { "a", "b", "c", "d" };   
        sort(Arrays.asList(datas), new ArrayList());   
    }   
   
}
  

面试题:编程实现全排列,选择排列java算法小谈


这段代码里面的return用的很厉害,大家自己慢慢体会一下~

下面是全排列的一种算法,也很巧妙简单~

    public class AllSort{  
    public static void main(String[] args) {  
        char buf[]={'a','b','c'};  
        perm(buf,0,buf.length-1);  
    }  
    public static void perm(char[] buf,int start,int end){  
        if(start==end){//当只要求对数组中一个字母进行全排列时,只要就按该数组输出即可(特殊情况)  
            for(int i=0;i<=end;i++){  
                System.out.print(buf);  
            }  
            System.out.println();     
        }  
        else{//多个字母全排列(普遍情况) 
            for(int i=start;i<=end;i++){//(让指针start分别指向每一个数) 
                char temp=buf[start];//交换数组第一个元素与后续的元素  
                buf[start]=buf;  
                buf=temp;  
                  
                perm(buf,start+1,end);//后续元素递归全排列  
                  
                temp=buf[start];//将交换后的数组还原  
                buf[start]=buf;  
                buf=temp;  
            }  
        }  
    }  
}

  


面试题:编程实现全排列,选择排列java算法小谈


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论