求整数数组的子集【C语言】

方法1:通过二进制位,因为n个整数数组的子集有2的n次方个,例如整数数组为{1,2,3},子集有2的3次方,8个;

期望的输出形式

其中需要了解关注的是

n&1判断最低位是否有数。如果一个子集为{2},利用二进制位2&1让其最低位空出来,依次类推。

n>>1结果是n/2

将n&1与n>>1结合就可以得到

若n=3(011); n&1=1 其最低位可以得到,n>>1 = 1;其次低位可以低到,

可以通过下面代码解读

复制代码
#include <stdio.h>
​
int main(int argc, char const *argv[])
{
    int n=3;
    int str1[3]={1,2,3}; // 定义一个数组
    int str2[3]={0};
    for (int i = 2; i >= 0; i--)
    {
        if(n&1)    // i=2 n=3 n&1=1 ; i=1 n=1 n&1=1 ; i=0 n=0 n&1=0
        {
            str2[i]=str1[i];// str2[2]=str1[2] ;str2[1]=str1[1] ; 
        }
        n >>= 1; // n=1 n=0
    }
    for (int i = 0; i < 3; i++)
    {
        printf("%d ",str2[i]); // str2[2]=str1[2] ;str2[1]=str1[1] ; str[0]未被赋值
    }
    
    return 0;
}
​

此时得到了

以上述思想求整数数组的子集

复制代码
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
​
int main(int argc, char const *argv[])
{
    int nums[3] = {1,2,3};
    int numsSize = 3;
    int num = pow(2,numsSize);
    int **returnColumnSizes;
    returnColumnSizes = (int**)malloc(sizeof(int*)*num);
    for(int i = 0; i < num; i++)  
    {
        returnColumnSizes[i] = (int*)malloc(sizeof(int)*numsSize);
    } 
    for(int i = 0; i < num; i++)
    {
        for(int j = 0;j < numsSize; j++)
        {
            returnColumnSizes[i][j] = 0;
            
        }
        
    }   
    for(int i = 0; i < num; i++)
    {
        for(int j = 0; j < numsSize; j++)
        {
            returnColumnSizes[i][j]=0;
            printf("%d ",returnColumnSizes[i][j]);
        }
        printf("\n");
    }
    printf("---------\n");
    for(int i = 0; i < num; i++)
    {
        
        int n=i;
        int k=0;
        while (n)
        {
            if(n&1)
            {
                returnColumnSizes[i][k]=nums[k];
            }
            n >>= 1;
            
            k++;
        }
        
        
    }
    printf("---------\n");
    
    for(int i = 0; i < num; i++)
    {
       
        for(int j = 0; j < numsSize; j++)
        {
            if(returnColumnSizes[i][j]==0)
            {
                continue;
            }
            printf("%d ",returnColumnSizes[i][j]);
             
        }
       
        printf("\n");
    }
   
}
​

本题本来打算写来回答力扣题78题求子集的,但是,才疏学浅,还是我不配。

最终结果将所有0都去掉了。

相关推荐
workflower4 小时前
单元测试-例子
java·开发语言·算法·django·个人开发·结对编程
YuanlongWang4 小时前
C# 基础——装箱和拆箱
java·开发语言·c#
MicroTech20256 小时前
微算法科技(MLGO)研发突破性低复杂度CFG算法,成功缓解边缘分裂学习中的掉队者问题
科技·学习·算法
墨染点香6 小时前
LeetCode 刷题【126. 单词接龙 II】
算法·leetcode·职场和发展
aloha_7897 小时前
力扣hot100做题整理91-100
数据结构·算法·leetcode
Tiny番茄7 小时前
31.下一个排列
数据结构·python·算法·leetcode
挂科是不可能出现的7 小时前
最长连续序列
数据结构·c++·算法
_Aaron___7 小时前
List.subList() 返回值为什么不能强转成 ArrayList
数据结构·windows·list
前端小L8 小时前
动态规划的“数学之魂”:从DP推演到质因数分解——巧解「只有两个键的键盘」
算法·动态规划
RTC老炮8 小时前
webrtc弱网-ReceiveSideCongestionController类源码分析及算法原理
网络·算法·webrtc