全排列

 

全排列代码

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

public class FullSort {

	private static void sort(List<String> datas, List<String> target, int size) {
		if (target.size() == size) {
			for (Object obj : target)
				System.out.print(obj);
			System.out.println();
			return;
		}
		for (int i = 0; i < datas.size(); i++) {
			List<String> newDatas = new ArrayList<String>(datas);
			List<String> newTarget = new ArrayList<String>(target);
			newTarget.add(newDatas.get(i));
			newDatas.remove(i);
			sort(newDatas, newTarget, size);
		}
	}

	public static void main(String[] args) {
		String[] datas = new String[] { "a", "b" };
		int size = datas.length;
		sort(Arrays.asList(datas), new ArrayList<String>(), size);
	}

}

代码2

改进  调用串的函数,将字符的操作变为字符串的操作,原理一样

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

public class NumTest {
    public static void main(String[] args) {
        String s="ABCD";//原字符串
        List<String> result = list(s, "");//列出字符的组合,放入result
        
        System.out.println(result.size());;
        System.out.println(result);
    }
    
    /**
     * 列出基础字符串(base)的所有组合
     * @param base 以该字符串作为基础字符串,进行选择性组合。
     * @param buff 所求字符串的临时结果
     * @param result 存放所求结果
     */
    public static List<String> list(String base,String buff){
     List<String> result = new ArrayList<String>();//存放结果信息。
        if(base.length()<=0){
            result.add(buff);
        }
        for(int i=0;i<base.length();i++){
         List<String> temp = list(new StringBuilder(base).deleteCharAt(i).toString(),buff+base.charAt(i));
         result.addAll(temp);
         
        }
        
        return result;
    }
}

代码2的另一种写法

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

public class NumTest {
	
	   public static void main(String[] args) {
	        String s="ABCD";//原字符串
	        List<String> result = new ArrayList<String>();//存放结果信息。
	        list(s, "", result);//列出字符的组合,放入result
	        System.out.println(result.size());;
	        System.out.println(result);
	    }
	    
	    /**
	     * 列出基础字符串(base)的所有组合
	     * @param base 以该字符串作为基础字符串,进行选择性组合。
	     * @param buff 所求字符串的临时结果
	     * @param result 存放所求结果
	     */
	    public static void list(String base,String buff,List<String> result){
	        if(base.length()<=0){
	            result.add(buff);
	        }
	        for(int i=0;i<base.length();i++){
	            list(new StringBuilder(base).deleteCharAt(i).toString(),buff+base.charAt(i),result);
	        }
	    }

}




 

 

posted on   小强斋太  阅读(223)  评论(0编辑  收藏  举报

编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示