C语言中,怎么把十进制转换成十六进制数
2个回答
展开全部
#include<stdio.h>
#include<stdlib.h>
//顺序栈定义
#define OK 1
#define ERROR 0
#define OVERFLOW -2
#define MAXSIZE 100
#define STACKINCREMENT 10
typedef int Status;
typedef int SElemType;
typedef struct {
SElemType *base;
SElemType *top;
int stacksize;
} SqStack;
//算法3.1 顺序栈的初始化
Status InitStack(SqStack &S) { // 构造一个空栈 S
S.base = new SElemType[MAXSIZE]; //为顺序栈分配最大容量为MAXSIZE的数组空间
if (!S.base)
exit(OVERFLOW); //存储分配失败
S.top = S.base;
S.stacksize = MAXSIZE;
return OK;
}
//算法3.2 顺序栈的入栈
Status StackEmpty(SqStack &S) {
return OK;
}
Status Push(SqStack &S, SElemType &e) { // 插入元素e为新的栈顶元素
if(S.top -S.base >=S.stacksize){
S.base =(SElemType*)realloc(S.base ,(S.stacksize+STACKINCREMENT)*sizeof(SElemType));
if(!S.base )exit(OVERFLOW);
S.top =S.base +S.stacksize ;
S.stacksize +=STACKINCREMENT;
}
*S.top++=e;
return OK;
}
//算法3.3 顺序栈的出栈
Status Pop(SqStack &S, SElemType &e) {
// 若栈不空,则删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERROR
if(S.top==S.base)return ERROR;
e=*--S.top;
return OK;
}
//算法3.4 取顺序栈的栈顶元素
Status GetTop(SqStack S, SElemType &e) {
// 若栈不空,则用e返回S的栈顶元素,并返回OK;否则返回ERROR
if (S.top == S.base)
return ERROR;
e = *(S.top - 1); //栈顶指针减1,将栈顶元素赋给e
return OK;
}
int main() {
SqStack s;
SElemType e;
SElemType n;
SElemType a;
printf( "需要转换的数是:");
InitStack(s);
scanf("%d",&n);
while(n!=0){
a=(SElemType)n%16;
Push(s,a);
n=n/16;
}
while(GetTop(s,e)==OK){
printf("%d ",e);
Pop(s,e);
}
return 0;
}
#include<stdlib.h>
//顺序栈定义
#define OK 1
#define ERROR 0
#define OVERFLOW -2
#define MAXSIZE 100
#define STACKINCREMENT 10
typedef int Status;
typedef int SElemType;
typedef struct {
SElemType *base;
SElemType *top;
int stacksize;
} SqStack;
//算法3.1 顺序栈的初始化
Status InitStack(SqStack &S) { // 构造一个空栈 S
S.base = new SElemType[MAXSIZE]; //为顺序栈分配最大容量为MAXSIZE的数组空间
if (!S.base)
exit(OVERFLOW); //存储分配失败
S.top = S.base;
S.stacksize = MAXSIZE;
return OK;
}
//算法3.2 顺序栈的入栈
Status StackEmpty(SqStack &S) {
return OK;
}
Status Push(SqStack &S, SElemType &e) { // 插入元素e为新的栈顶元素
if(S.top -S.base >=S.stacksize){
S.base =(SElemType*)realloc(S.base ,(S.stacksize+STACKINCREMENT)*sizeof(SElemType));
if(!S.base )exit(OVERFLOW);
S.top =S.base +S.stacksize ;
S.stacksize +=STACKINCREMENT;
}
*S.top++=e;
return OK;
}
//算法3.3 顺序栈的出栈
Status Pop(SqStack &S, SElemType &e) {
// 若栈不空,则删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERROR
if(S.top==S.base)return ERROR;
e=*--S.top;
return OK;
}
//算法3.4 取顺序栈的栈顶元素
Status GetTop(SqStack S, SElemType &e) {
// 若栈不空,则用e返回S的栈顶元素,并返回OK;否则返回ERROR
if (S.top == S.base)
return ERROR;
e = *(S.top - 1); //栈顶指针减1,将栈顶元素赋给e
return OK;
}
int main() {
SqStack s;
SElemType e;
SElemType n;
SElemType a;
printf( "需要转换的数是:");
InitStack(s);
scanf("%d",&n);
while(n!=0){
a=(SElemType)n%16;
Push(s,a);
n=n/16;
}
while(GetTop(s,e)==OK){
printf("%d ",e);
Pop(s,e);
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |