c语言十进制转二进制例题,c语言十进制转二进制

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

//用栈结构

#include

#include

typedef struct LNode

{

int data;

struct LNode *next;

}LNode,*LinkList;

/*初始化*/

LinkList creatLNode(LinkList L)

{

L=(LinkList)malloc(sizeof(LNode));

L->next=NULL;

return L;

}

/*转制*/

void zhuanzhi(LinkList L,int data)

{

int sign=1,yushu,shang=data;

LinkList p;

if(data<0)

{

shang=-data;

sign=-1;

}

if(data==0)

printf("该十进制整数对应的二进制数为:\n0\n");

while(shang>0)

{

yushu=shang%2;

p=(LinkList)malloc(sizeof(LNode));

if(!p)

exit(-2);

p->data=yushu;

p->next=L->next;

L->next=p;

shang/=2;

}

if(sign==-1)

{

printf("该十进制整数对应的二进制数为:\n");

printf("-");

}

for(p=L->next;p!=NULL;p=p->next)

printf("%d",p->data);

printf("\n");

}

/*销毁栈*/

void del(LinkList L)

{

LinkList p=L,q;

while(!p)

{

q=p;

p=p->next;

free(q);

}

}

void main()

{

int data;

LinkList L;

L=creatLNode(L);

printf("请输入要转换的十进制数:");

scanf("%d",&data);

zhuanzhi(L,data);

del(L);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值