zoukankan      html  css  js  c++  java
  • 采用位图求数组或者字符串的所有子序列

    /**
     * //采用位图求一个数组的子集
     * //采用位图求一个字符串的所有子序列
     */
    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 + " ");
    
            }
        }
    
    }
    

      

  • 相关阅读:
    POJ 2251 Dungeon Master(BFS)
    POJ 1321 棋盘问题 (DFS + 回溯)
    POJ 3009 Curling 2.0(DFS + 模拟)
    Codeforces 702D Road to Post Office(模拟 + 公式推导)
    Codeforces 702A Maximum Increase(dp)
    Codeforces 702C Cellular Network(二分)
    Codeforces 702B Powers of Two
    POJ 3083 Children of the Candy Corn (DFS + BFS + 模拟)
    POJ 2488 A Knight's Journey (回溯法 | DFS)
    POJ1094 Sorting It All Out (拓扑排序)
  • 原文地址:https://www.cnblogs.com/moris5013/p/12994351.html
Copyright © 2011-2022 走看看