#include"malloc.h"
typedef struct
{ int vec[4];
int top;
}stack;
void push(stack *s,int x)
{ if(s->top==4-1) printf("栈上益处,满了!");
else
{ s->top++;
s->vec[s->top]=x;
}
}
//初始化栈指针
void instack(stack *s)
{ s->top=-1;
}
//读栈顶元素
void top(stack *s,int x)
{ if(s->top==0) printf("无栈顶元素!");
else x=s->vec[s->top];
}
//出栈
void pop(stack *s)
{ if(s->top==0) printf("栈下益出,空了!");
else s->top--;
}
//取栈顶元素
int ptop(stack *s)
{ int x;
top(s,x); //将栈顶元素赋给x
pop(s); //将栈顶元素弹出
return x;
}
main()
{ stack *s;
int x,i;
s=(stack*)malloc(sizeof(stack));
for(i=0;i<4;i++)
scanf("%d",&x);
instack(s);
push(s,x);
for(i=0;i<4;i++)
printf("%d",ptop(s));
}
//这个怎么不能输出?
----------------解决方案--------------------------------------------------------
#include"stdio.h" #include"malloc.h" typedef struct { int vec[4]; int top; }stack; void push(stack *s,int x) { if(s->top==4-1) printf("栈上益处,满了!"); else { s->top++; s->vec[s->top]=x; } }
void instack(stack *s) { s->top=-1; }
void top(stack *s,int *x) { if(s->top==-1) printf("无栈顶元素!"); else *x=s->vec[s->top]; }
void pop(stack *s) { if(s->top==-1) printf("栈下益出,空了!"); else s->top--; }
int ptop(stack *s) { int x; top(s,&x); pop(s); return x; } main() { stack *s; int x,i; s=(stack*)malloc(sizeof(stack)); instack(s); for(i=0;i<4;i++) {scanf("%d",&x);
push(s,x); } for(i=0;i<4;i++) printf("%d",ptop(s)); getch(); } 帮你改了一下!可以了!
----------------解决方案--------------------------------------------------------
我已经搞定了, 不过第一个回帖子的赏100金块!
----------------解决方案--------------------------------------------------------