离散数学求幂集

博客介绍了利用十进制转二进制对集合中元素进行编码来求集合幂集的方法,该方法主要应用离散数学知识求解,还提到会运行测试不同情况查看结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

离散数学求幂集

这是一个利用十进制转二进制,对集合中元素进行编码从而求集合的幂集

#include<stdio.h>
#include<string.h>
#include<math.h>
int b[100];
void turn(int x){
	int i=0;
	memset(b,0,sizeof(b));
	for(i=0;i<100;i++)
	{
		b[i]=x%2;
		x=x/2;
	}
	
}
 int main()
 { 
 void turn(int x);
 char a[100][20];
 memset(a,'\0',sizeof(a));
 	int i,n,j=0;
 	int K;
 	printf("请输入一个集合中元素个数:\n");
 	scanf("%d",&n);
 	K=pow(2,n);
 	printf("请输入集合的元素(以空格断开):\n");
 	for(i=0;i<n;i++)scanf("%s",a[i]);
 	printf("该集合的幂集:\n");
	 printf("{");
 	
    for(i=1;i<K;i++){
    	turn(i);
    		 printf("{");
    	for(j=0;j<n;j++){
    		if(b[j])printf("%5s",a[j]);
	 }	 printf("}");
	}
 		 printf("空集}");
	 return 0;
 }

我们来运行一下,试下不同的情况,看一下结果
在这里插入图片描述在这里插入图片描述
这个主要应用的是离散数学中的知识进行求解。
注:第一次写博客,喜欢的话支持一下,谢谢啦!!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@别样

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值