打印n个元素集合的幂集

用一个树实现,左边选,右边不选

#include<iostream.h>
#include<string.h>
#include<stdio.h>

typedef struct node
{
 int data;
 struct node *next;
}Node;

int ListInsert(Node *list,int k,int a)
{
 //int len=ListLen(list);

  Node *p,*q;
  int i=0;
  p=list;
  while(p->next&&i<k)
  {
   i++;
   p=p->next;
  }
  q=new Node[1];
  q->data=a;
  q->next=p->next;
  p->next=q;
  return 1;

}

int ListDelete(Node *list)
{
 Node *p;
 while(list->next)
 {  
  p=list;
  list=list->next;
 }
 p->next=NULL;
 return 1;

}

int ListLen(Node *list)
{
 int len=0;
 while(list)
 {
  len++;
  list=list->next;
 }
 return len;
}

void print(Node *list)
{
 Node *p=list;
 while(p)
 {
  if(p->data!=0)
   printf("%d",p->data);
  p=p->next;
 }
}

int ListGetItem(Node *head,int i)
{
 if(i>ListLen(head))
  return -1;
 int len=0;
 while(head->next&&len+1<i)
 {
  len++;
  head=head->next;
 }
 return head->data;

}
void GetPowerSet(int i,Node *a,Node *b)
{
 if(i>ListLen(a))
 {
  print(b);
  cout<<endl;
 }
 else
 {
  int  x=ListGetItem(a,i);
  int k=ListLen(b);
     ListInsert(b,k+1,x);
  GetPowerSet(i+1,a,b);
     ListDelete(b);
  GetPowerSet(i+1,a,b);
 }
}

void main()
{
 Node *head=new Node[1];
 head->data=1;
 head->next=NULL;

 Node *b=new Node[1];
 b->data='/0';
 b->next=NULL;
 
 ListInsert(head,2,2);
 ListInsert(head,100,3);
 GetPowerSet(1,head,b); 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值