十进制转二进制c语言数据结构,数据结构C语言将一个十进制数转换成另外一个P进制数字符串(可以是二进制到十六进制)...

数据结构,C语言实现将一个十进制数转换成另外一个P进制数字符串(可以是二进制到十六进制)转换函数的原型为:

void Convert (int n, char str[], unsigned P);

n:输入,待转换的数

str:输出,转换好的P进制字符串

P:输入,要转换的进制,取值可从2到16。如果在这范围之外,可认为输入错,不做转换。

先求得的余数在写出结果时最后写出,最后求出的余数最先写出,符合栈的LIFO性质,故可用栈来实现数制转换。

实验课题一: 将一个十进制数转换成另外一个P进制数字符串(可以是二进制到十六进制)。转换函数的原

型为:

void Convert (int n, char str[], unsigned P);

n:输入,待转换的数

str:输出,转换好的P进制字符串

P:输入,要转换的进制,取值可从2到16。如果在这范围之外,可认为输入错,不做转换。 将一个整数转换成P进制的数,我们可以采用如下的方法:

例:十进制转换成八进制(P等于8):(66)10=(102)8

66/8=8 余 2

8/8 =1 余 0

1/8 =0 余 1

当商为0时转换结束,转换结果为上述过程余数序列的逆序:102。

先求得的余数在写出结果时最后写出,最后求出的余数最先写出,符合栈的LIFO性质,故可用栈来实现数

制转换。

#include

#include

#define maxsize 100

typedef struct

{

char data[maxsize];

int top;

}sqstack,*Stack;

Stack initstack()

{

Stack s;

s=(Stack)malloc(sizeof(sqstack));

s->top=-1;

return s;

}

int push(Stack s,char ch)

{

if(s->top>=maxsize)

return 0;

else

{

s->data[++s->top]=ch;

return 1;

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值