用栈实现10进制到16进制的转换帮忙修改一下
#include<stdio.h>typedef struct
{int a[10];
int top;}stack;
void main()
{
void push(stack s,int n);
int n;
stack s;
//s.a[10]={0};
s.top=0;
printf("input a hex number:\n");
scanf("%d",&n);
while(n)
{ push(s,n%16);
n/=16;
}
while(s.top!=0)
{printf("%d",s.a[s.top]);s.top--;}
}
void push( stack s,int n)
{ s.a[s.top]=n;s.top++;
}
搜索更多相关的解决方案:
进制
----------------解决方案--------------------------------------------------------
我想,LZ需要注意的问题有以下几点。。。。。。
1、在LZ 中的 push(stack s,int n) 这个函数中,stack s 只是一个形式参数,不代表main()函数中的stack类型变量 s;
2、LZ中的s.top不是指向栈顶元素,只是指向栈项元素的上面的一个位置。。。。
下面是我改写后的代码,用了C++中的传递实参的语法。。
#include<stdio.h>
typedef struct
{int a[10];
int top;}stack;
void main()
{
void push(stack &s,int n);
int n;
stack s;
//s.a[10]={0};
// s.top=0;
s.top=-1;
printf("input a hex number:\n");
scanf("%d",&n);
while(n)
{ push(s,n%16);
n/=16;
}
while(s.top>=0)
{printf("%d",s.a[s.top]);s.top--;}
}
void push( stack &s,int n) // stack &s 中的 "&" 表示
{ //s.a[s.top]=n;s.top++; //在调用时传递的是实际参数 ,这是C++中的语法
s.top++;s.a[s.top]=n; // 在C语言中要传实参,只能通过用指针传递地址进行实现。
}
[[italic] 本帖最后由 布拉莫斯 于 2007-12-20 12:47 编辑 [/italic]]
----------------解决方案--------------------------------------------------------