求整数数组的子集【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都去掉了。

相关推荐
vibecoding日记13 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr213816 小时前
Verilog参数化游程编码RLE模块
算法
望易16 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络20 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩2 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹2 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术2 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc