标题:在家写了一个栈的基本操作,编译连接都没有问题,可是一调试就自动关闭,好 ...
只看楼主
北温终别
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2015-11-7
结帖率:0
已结贴  问题点数:20 回复次数:1 
在家写了一个栈的基本操作,编译连接都没有问题,可是一调试就自动关闭,好几次写程序都这样,望大神指教一下
程序附上:

#include<stdlib.h>
#include<stdio.h>
#define ERROR 0
#define OK 1
#define STACK_INIT_SIZE 8;
#define STACKINCREMENT 2;

typedef struct{
    int *base;
    int *top;
    int stacksize;
}SqStack;


int Initstack(SqStack &s){
    s.base=(int *)malloc(8*sizeof(int));
    if(!s.base)  return 0;
    s.base=s.top;
    s.stacksize=STACK_INIT_SIZE;
    return 1;
}

int Push(SqStack &s,int e){
    if(s.top-s.base>=s.stacksize)
{
    s.base=(int*)realloc(s.base,sizeof(int)*4);
     if(!s.base)  
         return 0;
     s.top=s.base+s.stacksize;
     s.stacksize+=STACKINCREMENT;
}
    *s.top++=e;
    return e;
    return 1;
}


int StackEmpty(SqStack &s){
    if(s.base==s.top)
        return 1;
    else
        return 0;
}

int Pop(SqStack &s,int &e){
    if(s.base==s.top)
        return ERROR;
    e=*--s.top;
    return 1;
}

SqStack main(int N){
    SqStack s;
    int e;
       Initstack(s);
    scanf("%d",N);
    while(N){
        Push(s,N % 8);
        N=N/8;
    }
    while(!StackEmpty(s)){
        Pop(s,e);
        printf("%d",e);
    }
        return s;
}





   
搜索更多相关主题的帖子: include return 在家 
2016-07-17 16:49
书生牛犊
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:星夜征程
等 级:贵宾
威 望:10
帖 子:1101
专家分:5265
注 册:2015-10-27
得分:20 
对这种程序我也没经验。
一般我的main都是int的。。。
可能你是设计了一个类似于Java类的东西。整个是打包的。
程序代码:
#include<stdlib.h>
#include<stdio.h>
#define ERROR 0
#define OK 1
#define STACK_INIT_SIZE 8;
#define STACKINCREMENT 2;

typedef struct{
    int *base;
    int *top;
    int stacksize;
}SqStack;


int Initstack(SqStack &s){
    s.base=(int *)malloc(8*sizeof(int));
    if(!s.base)  return 0;
    s.top=s.base;       //s.top还没初始化吧?你是不是反了
    s.stacksize=STACK_INIT_SIZE;
    return 1;
}

int Push(SqStack &s,int e){
    if(s.top-s.base>=s.stacksize)
{
    s.base=(int*)realloc(s.base,sizeof(int)*4);
     if(!s.base)
         return 0;
     s.top=s.base+s.stacksize;
     s.stacksize+=STACKINCREMENT;
}
    *s.top++=e;
    return e;
    return 1;
}


int StackEmpty(SqStack &s){
    if(s.base==s.top)
        return 1;
    else
        return 0;
}

int Pop(SqStack &s,int &e){
    if(s.base==s.top)
        return ERROR;
    e=*--s.top;
    return 1;
}

int main(){//这里的用法。。。说老实话,我是不太懂啦,我改成int了,你随意
int N;
    SqStack s;
    int e;
       Initstack(s);
    scanf("%d",&N);//这里是不是少了 & ?
    while(N){
        Push(s,N%8);
        N=N/8;
        printf("{%d}",N);//这里我加了一个检测,你看看是不是你要的结果,我是看不懂这程序想干嘛啦
    }
    while(!StackEmpty(s)){
        Pop(s,e);
        printf("%d",e);
    }
        return 0;
}
目前来看,程序是能跑了。。。但我不知道你要实现的是什么功能。
如果说你只是想做个栈,我建议你用链表。每次插入在表头,读取从表头,什么时候链表读完了栈就清空了。而且这样做的栈内存也会比较大。

φ(゜▽゜*)♪
2016-07-20 12:24



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




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

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