C语言用栈存储学生信息,严蔚敏版数据结构建立学生信息顺序栈C语言版.doc

#include

#include

#define STACK_INIT_SIZE 100

#define STACKINCREMENT 10

typedef struct Student/*定义学生类 */

{

int num;

char name[20];

char sex[2];

int age;

float grade;

}stu;

typedef struct

{

stu *base;

stu *top;

int stacksize;

}sqstack;

sqstack InitStack()/*构造一个空栈*/

{

sqstack s;

s.base=(stu*)malloc(STACK_INIT_SIZE*sizeof(stu));

if(!s.base)

printf("OVERFLOW\n");

else

{

s.top=s.base;

s.stacksize=STACK_INIT_SIZE;

printf("OK\n");

return s;

}

}

void DestroyStack(sqstack *s)/*销毁栈*/

{

s->base=NULL;

free(s->base);

printf("OK\n");

}

void ClearStack(sqstack *s)/*将栈清空为空栈*/

{

s->top=s->base;

printf("OK\n");

}

void StackEmpty(sqstack *s)/*若为空栈返回TRUE,否则返回FLASE*/

{

if(s->base==NULL)

printf("栈不存在.\n");

else if(s->top==s->base)

printf("TRUE\n");

else

printf("FLASE\n");

}

int StackLength(sqstack *s)

{

if(s->base==NULL)

return(-1);

else

return(s->top-s->base);

}

stu GetTop(sqstack *s)/*返回栈顶元素 */

{

if(s->top==s->base)

printf("ERROR\n");

else

{

printf("OK\n");

return *(s->top-1);

}

}

void Push(sqstack *s)/*插入新元素*/

{

stu *newbase;

if(s->top-s->base>=s->stacksize)

{

newbase=(stu*)realloc(s->base,(s->stacksize+STACKINCREMENT)*sizeof(stu));

if(!newbase)

printf("OVERFLOW\n");

else

{

s->top=s->base+s->stacksize;

s->stacksize=s->stacksize+STACKINCREMENT;

printf("请输入插入学生的数据\n学号:");

scanf("%d",&s->top->num);

printf("姓名:");

scanf("%s",&s->top->name);

printf("年龄:");

scanf("%d",&s->top->age);

printf("性别:");

scanf("%s",&s->top->sex);

printf("成绩:");

scanf("%f",&s->top->grade);

s->top++;

}

}

else

{

printf("请输入插入学生的数据\n学号:");

scanf("%d",&s->top->num);

printf("姓名:");

scanf("%s",&s->top->name);

printf("年龄:");

scanf("%d",&s->top->age);

printf("性别:");

scanf("%s",&s->top->sex);

printf("成绩:");

scanf("%f",&s->top->grade);

s->top++;

}

}

stu Pop(sqstack *s)/*删除栈顶元素,返回其值*/

{

stu e;

if(s->top==s->base)

printf("ERROR\n");

else

{

e=*(s->top-1

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值