给定一个数组,m个数和为n的组合

public static List<List<Integer>> calSum(int[] arr,int n,int m){
        if(arr==null){
            return null;
        }
        List<List<Integer>> ans = new ArrayList<>();
        int len = arr.length;
        int bit = 1 << len;
        for(int i = 0;i<bit ;i++){
           if(numOf1(i)==m){
               int sum=0;
               List<Integer> list = new ArrayList<>();
               for(int j=0;j<len;j++){
                   if((i & 1 << j)!=0){
                       sum+= arr[j];
                       list.add(arr[j]);
                   }
               }
               if(sum==n){
                   ans.add(list);
               }
           }
        }
        return ans;
    }

统计一个数中二进制的个数

public static int numOf1(int n){
        int count = 0;
        while(n!=0){
            ++count;
            n = n & (n-1);
        }
        return count;
    }
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容