| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 497 人关注过本帖
标题:这个堆栈的问题怎么不能输出?
只看楼主 加入收藏
想你的天空
Rank: 2
等 级:新手上路
威 望:5
帖 子:610
专家分:0
注 册:2004-12-30
收藏
 问题点数:0 回复次数:2 
这个堆栈的问题怎么不能输出?
#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==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));
}
//这个怎么不能输出?
搜索更多相关主题的帖子: 堆栈 输出 
2005-03-31 17:29
空前
Rank: 1
等 级:新手上路
帖 子:1146
专家分:0
注 册:2004-5-11
收藏
得分:0 

#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(); } 帮你改了一下!可以了!


2005-03-31 19:19
想你的天空
Rank: 2
等 级:新手上路
威 望:5
帖 子:610
专家分:0
注 册:2004-12-30
收藏
得分:0 
我已经搞定了, 不过第一个回帖子的赏100金块!

2005-03-31 21:47
快速回复:这个堆栈的问题怎么不能输出?
数据加载中...
 
   



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

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