标签:private ++ csharp abc 位图 组合 int app rgs
/** * //采用位图求一个数组的子集 * //采用位图求一个字符串的所有子序列 */ public class Test3 { public static void main(String[] args) { // allSub(); allSub("abc"); } private static void allSub() { //[] [1] [2] [3] [1,2] [1,3] [2,3] [1,2,3] int [] arr = {1,2,3}; List<List<Integer>> allList = new ArrayList<List<Integer>>(); int len = arr.length; //mask表示的就是所有的可能组合,整数是0到7,用二进制表示就是000 001 010 011 100 101 110 111 for(int mask = 0; mask < (1<<len); mask++){ List<Integer> aList = new ArrayList<Integer>(); //内层循环表示的作用是选出原数组和(比如001)相&后的元素 for(int i = 0; i < len; i++){ if(((1<<i) & mask )!= 0){// 1<<i 表示的是001 010 100,可以得出mask中哪几个是1 aList.add(arr[i]); } } allList.add(aList); } for (List<Integer> list : allList){ for (Integer i : list){ System.out.print(i + " "); } System.out.println(); } } private static void allSub(String str) { //[] [1] [2] [3] [1,2] [1,3] [2,3] [1,2,3] char [] arr = str.toCharArray(); List<String> allList = new ArrayList<String>(); int len = arr.length; //mask表示的就是所有的可能组合,整数是0到7,用二进制表示就是000 001 010 011 100 101 110 111 for(int mask = 0; mask < (1<<len); mask++){ StringBuffer sb = new StringBuffer(); //内层循环表示的作用是选出原数组和(比如001)相&后的元素 for(int i = 0; i < len; i++){ if(((1<<i) & mask )!= 0){// 1<<i 表示的是001 010 100,可以得出mask中哪几个是1 sb.append(arr[i]); } } allList.add(sb.toString()); } for (String s : allList){ System.out.println(s + " "); } } }
标签:private ++ csharp abc 位图 组合 int app rgs
原文地址:https://www.cnblogs.com/moris5013/p/12994351.html