用栈实现十进制转换为二进制
2012-11-24 17:57
148 查看
#include<stdio.h>
#include<malloc.h>
#include<math.h>
#include<string.h>
#include "process.h"
#define SIZE 100
#define STACKINCREMENT 10
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
typedef int Status;
typedef struct
{
int a;
} SElemType;
typedef struct
{
SElemType *base;
SElemType *top;
int stacksize;
} SqStack;
SqStack S; //定义全局变量
Status InitStack(SqStack *S)
{
S->base=(SElemType *)malloc(SIZE*sizeof(SElemType));
if(!S->base) exit(OVERFLOW);
S->top=S->base;
S->stacksize=SIZE;
return OK;
}
Status Push(SqStack *S,SElemType e)
{
if(S->top-S->base>=S->stacksize)
{
S->base=(SElemType *)malloc((S->stacksize+STACKINCREMENT)*sizeof(SElemType));
if(!S->base) exit(OVERFLOW);
S->top=S->base+S->stacksize;
S->stacksize+=STACKINCREMENT;
}
*S->top++=e;
//printf("%dwww\n",*--S->top);
return OK;
}
Status Stackempty(SqStack *S)
{
if(S->top==S->base)
return TRUE;
else
return FALSE;
}
Status Pop(SqStack *S,SElemType *e)
{
if(S->top==S->base) return ERROR;
*e=*--S->top;
return OK;
}
Status DtoBTrans(int N,SqStack *S)
{
SElemType e;
while(N)
{
e.a=N%2;
Push(S,e);
N=N/2;
}
while(!Stackempty(S))
{
Pop(S,&e);
printf("%d",e);
}
return OK;
}
void main()
{
int x;
InitStack(&S);
printf("请输入十进制数:");
scanf("%d",&x);
DtoBTrans(x,&S);
}
运行结果:
#include<malloc.h>
#include<math.h>
#include<string.h>
#include "process.h"
#define SIZE 100
#define STACKINCREMENT 10
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
typedef int Status;
typedef struct
{
int a;
} SElemType;
typedef struct
{
SElemType *base;
SElemType *top;
int stacksize;
} SqStack;
SqStack S; //定义全局变量
Status InitStack(SqStack *S)
{
S->base=(SElemType *)malloc(SIZE*sizeof(SElemType));
if(!S->base) exit(OVERFLOW);
S->top=S->base;
S->stacksize=SIZE;
return OK;
}
Status Push(SqStack *S,SElemType e)
{
if(S->top-S->base>=S->stacksize)
{
S->base=(SElemType *)malloc((S->stacksize+STACKINCREMENT)*sizeof(SElemType));
if(!S->base) exit(OVERFLOW);
S->top=S->base+S->stacksize;
S->stacksize+=STACKINCREMENT;
}
*S->top++=e;
//printf("%dwww\n",*--S->top);
return OK;
}
Status Stackempty(SqStack *S)
{
if(S->top==S->base)
return TRUE;
else
return FALSE;
}
Status Pop(SqStack *S,SElemType *e)
{
if(S->top==S->base) return ERROR;
*e=*--S->top;
return OK;
}
Status DtoBTrans(int N,SqStack *S)
{
SElemType e;
while(N)
{
e.a=N%2;
Push(S,e);
N=N/2;
}
while(!Stackempty(S))
{
Pop(S,&e);
printf("%d",e);
}
return OK;
}
void main()
{
int x;
InitStack(&S);
printf("请输入十进制数:");
scanf("%d",&x);
DtoBTrans(x,&S);
}
运行结果:
相关文章推荐
- 用栈实现十进制到二进制的转换
- 利用CONNECT BY实现二进制到十进制的转换
- 数据结构5:利用栈实现二进制到十进制的转换
- 用栈实现进制转换十进制转换成:二进制数、八进制数、十六进制数
- 在BASH下简单实现十进制到二进制和十六进制的转换
- 位运算实现十进制转换为二进制
- 十进制转换到二进制(用自定义的栈实现
- 位运算实现 十进制(正负)转换成二进制
- 使用bitset实现二进制和十进制的相互转换
- C++实现二进制、八进制、十进制、十六进制的相互转换
- 代码实现十进制转换为二进制、十六进制(源码)
- 用位运算实现十进制转换为二进制
- C语言实现十进制转换成二进制
- 利用栈实现二进制转换为十进制
- Java使用bit array实现二进制,十进制,十六进制值之间的转换
- 使用bitset实现二进制和十进制的相互转换
- js实现二进制与十进制的相互转换
- 用C#代码实现二进制与十进制的互相转换
- 用递归实现十进制转换成二进制
- 将十进制整形数转换成二进制,然后通过字符型输出 自己实现的一个简单的例子