网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
06月28日漏签0天
数据结构吧 关注:104,535贴子:883,681
  • 看贴

  • 图片

  • 吧主推荐

  • 视频

  • 游戏

  • 2回复贴,共1页
<<返回数据结构吧
>0< 加载中...

求大神帮忙看看程序哪有问题,一运行就崩溃了。压栈和弹栈。

  • 只看楼主
  • 收藏

  • 回复
  • 二中小强人
  • 单链表
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
#include<stdio.h>
#include<stdlib.h>
#define STACK_SIZE 10
#define INCREASESIZE 1
typedef struct {
int stacksize;
int* base;
int* top;
}sqstack,*STACK;
void initstack(STACK S){
S->base=(int*)malloc(STACK_SIZE*sizeof(int));
S->top=S->base;
S->stacksize=STACK_SIZE;
}
void push(STACK S,int newdata){//压栈
if(S->top-S->base>STACK_SIZE){
S->base=(int*)realloc(S->base,(S->stacksize+INCREASESIZE)*sizeof(int));
S->top=S->base+S->stacksize;
++S->stacksize;
}
*S->top=newdata;
S->top++;
}
void pop(STACK S){//弹栈
if(S->top>S->base)
--S->top;
}
void printfstack(STACK S){
int* work=S->base;
while(S->top>work){
printf("%d ",*work);
work++;
}
}
main()
{
int num,i,newdata;
sqstack mystack;//其实所有的表在声明时都是结构体
initstack(&mystack);
printf("初始化成功!\n");
printf("请输入要创建的栈长度\n");
scanf("%d",&num);
for(i=1;i<=num;i++)
{
printf("请输入第%d个数 ",i);
scanf("%d",&newdata);
push(&mystack,newdata);
}
printf("压栈成功!\n");
//printstack(&mystack);
printfstack(&mystack);
printf("\n打印成功!\n");
pop(&mystack);
printf("\n弹栈成功!\n");
printfstack(&mystack);
printf("\n打印成功!\n");
system("pause");
return 0;
}


  • 二中小强人
  • 单链表
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
木有人帮偶吗


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 2回复贴,共1页
<<返回数据结构吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示