C:堆栈实现

时间:2015-01-26 11:40:33

标签: c stack runtime-error

下面的堆栈实现代码,产生运行时错误,虽然它确实编译..任何人都可以帮我识别发现错误?

#include<stdio.h>
#define size 5

//声明了一个堆栈结构,它有一个int数组,顶部是它的成员..

struct stack{
   int a[size],top;
}s;

//在检查堆栈是否溢出后调用时,跟随方法在堆栈中推送元素'item'?

void push(int item){
if(s.top >= size-1)
    printf("\nStack overflow..\n");
else
    s.a[++s.top] = item;
}

以下方法在调用时弹出一个元素..

int pop(){
if(s.top == -1){
    printf("\n..Stack underflow..\n");
    return 0;
}
return s.a[s.top];
}

//显示堆栈中的元素,直到[top]

void display(){
int i;
for(i = s.top; i>=0; i--){
    printf("\n%d", &s.a[i]);
}
}

// main()方法..

int main(){
s.top = -1;
int item, choice;
char ans;

printf("  ..Stack Implementation..\n");
printf("-----------------------------");
do{
    printf("\nMain Menu");
    printf("\n-------------");
    printf("\n     1. Push\n     2. Pop\n     3. Display\n     4. Exit\n");
    printf("\n  Enter your choice: ");
    scanf("%d", choice);

    switch(choice){
    case 1:
        printf("\nEnter item to be pushed:  ");
        scanf("%d", &item);
        push(item);
        break;
    case 2:
        pop();
        break;
    case 3:
        display();
        break;
    case 4:
        return 0;
    }
    printf("\n Want to continue? :");
    scanf("%c", &ans);
}while(ans == 'Y' || ans == 'y');
    return 0;
}

1 个答案:

答案 0 :(得分:3)

有一个小错字[我想是这样,因为你的其他事件是正确的]。变化

scanf("%d", choice);

scanf("%d", &choice);

此外,scanf("%c", &ans);中存在一个小问题。它将受到先前按下的 enter 的影响。使用

scanf(" %c", &ans);  //mind the space before %

其他问题:[编辑后添加]

  1. printf("\n%d", &s.a[i]); - 摆脱&printf()
  2. 中不需要它
  3. return s.a[s.top];应为return s.a[s.top--];