标题:新手求教,用栈实现的数制转换,哪儿不对啊
只看楼主
宁缺
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2015-5-10
结帖率:0
已结贴  问题点数:20 回复次数:3 
新手求教,用栈实现的数制转换,哪儿不对啊
#include<stdio.h>
#include<stdlib.h>
#define  STACK_INIT_SIZE  100
#define  STACKINCREMENT    10
typedef struct {
   int * base;
   int * top;
   int  stacksize;
}SqStack;
void InitStack(SqStack&S){
S.base=(int *)malloc(STACK_INIT_SIZE*sizeof(int));
if(!S.base)printf("overflow");
S.top=S.base;
S.stacksize=STACK_INIT_SIZE;
   }
void Push (SqStack &S,int e){
     //插入元素e为新的栈顶元素
     if(S.top-S.base>=S.stacksize){
          //---栈满,追加存储空间---
          S.base=(int *)realloc(S.base,
                              (S.stacksize+STACKINCREMENT)
                               *sizeof(int));
          if(!S.base)printf("overflow");//存储分配失败
          S.top=S.base+S.stacksize;   
          S.stacksize+=STACKINCREMENT;}
    *S.top++=e;
   
}//Push
void  Pop( SqStack &S,int &e){
      //若栈不空,则删除s的栈顶元素,
      //用e返回其值,并返回OK;
      //否则返回ERROR
      if(S.top = S.base) printf("error");
       e = *--S.top;
      
} // Pop
int StackEmpty(SqStack&S){
if(S.top = S.base)
return 1;
else
return 0;
}
        
void  conversion (int N) {
        //对于输入的任意一个非负十进制整数,打印输出与其等值的八进制数
            SqStack S;
            int e;
            InitStack(S);  //构造空栈
            while(N){
                     Push(S,N%8);
                     N = N/8; }
                 while (!StackEmpty(S)) {
                     
                       Pop(S, e);
                       printf("%",e);}
        } //Conversion
void main(){
    int N;
    printf("请输入一个非负十进制整数");
        scanf("%d",&N);
    conversion(N);

}
用栈实现数制转换,运行结果不对,哪儿错了啊
搜索更多相关主题的帖子: include 空间 元素 
2015-05-10 20:45
梦巷
Rank: 2
等 级:论坛游民
帖 子:14
专家分:15
注 册:2015-4-18
得分:0 
#include<stdio.h>
#include<stdlib.h>
int i=0;
typedef struct node
{
   int date;
   struct node *next;   
}Nt;
 typedef struct stake
 {
     Nt *top;
     Nt *base;
 }stack;
  void initstack(stack *p )
  {
      Nt *p1;
      p->top=p1=(Nt*)malloc(sizeof(Nt));
      p->top=p->base;
      p1->next=NULL;
  }
 void push(stack *p,int n)
  {
          Nt *p1;
          p1=(Nt*)malloc(sizeof(Nt));
          p1->date=n;
        p1->next=p->top;
          p->top=p1;
          i++;
  }
  int *pop(stack *p,int *e)
  {   
   while(p->top!=p->base)
  {
    e=p->top;   
      p->top=p->top->next;
      return e;
  }
  }
  main( )
  { stack s;
    initstack(&s);
      int N;
      int b=1,m;
    int *e;
      printf("请输入一个整数\n");
      scanf("%d",&N);
      printf("请输入要转化成的进制数\n");
      scanf("%d",&m);
      do   
      {  
         push(&s,N%m);
        N=N/m;        
        
      }
      while(N!=0);
      
      while(b<=i)
      {
        e=pop(&s,&e);
     
      printf("%d",*e);
     b++;
  }
  }
2015-05-17 10:37
林月儿
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:湖南
等 级:版主
威 望:138
帖 子:2276
专家分:10647
注 册:2015-3-19
得分:10 
回复 2楼 梦巷
#include<stdio.h>
#include<stdlib.h>
int i=0;
typedef struct node{
   int date;
   struct node *next;   
}Nt;
typedef struct stake{
     Nt *top;
     Nt *base;
}stack;
  void initstack(stack *p ){
      Nt *p1;
      p->top=p1=(Nt*)malloc(sizeof(Nt));
      p->top=p->base;
      p1->next=NULL;
  }
void push(stack *p,int n){
         Nt *p1;
          p1=(Nt*)malloc(sizeof(Nt));
          p1->date=n;
        p1->next=p->top;
          p->top=p1;
          i++;
}
Nt *pop(stack *p,Nt *e){  
 while(p->top!=p->base) {
      e=p->top;   
      p->top=p->top->next;
      return e;
  }
}
main( ){
  stack s;
  initstack(&s);
  int N;
  int b=1,m;
  Nt *e;
  printf("请输入一个整数\n");
  scanf("%d",&N);
  printf("请输入要转化成的进制数\n");
  scanf("%d",&m);
   do {  
         push(&s,N%m);
        N=N/m;        
        
   }
   while(N!=0);
   while(b<=i){
    e=pop(&s,e);
     printf("%d",*e);
    b++;
  }
}

剑栈风樯各苦辛,别时冰雪到时春
2015-05-17 11:51



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-445112-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.170831 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved