haokeaiaheng 2016-04-10 09:33 采纳率: 0%
浏览 1820
已结题

关于结构体指针什么时候申请空间的问题

/*顺序栈的初始化*/

#include
#include
#include

#define stack_size 3
#define error -1
typedef struct student{
int num;
char name[10];//定义数组时开辟了空间
}student,*Student;//栈中的元素
typedef struct linkstack
{
student children[100];
int top;
int base;
int stacksize;
}stack,*Stack;//栈的特性

stack* initstack(int stasize)
{
int i;
stack List;
stack* list;
List.base=0;
List.top=0;
List.stacksize=stasize;//初始化一个空栈

for(i=0;i<stasize;i++)
{
    printf("请输入姓名");
    scanf("%s",((List.children[i]).name));//数组指针的用法
    printf("请输入学号");
    scanf("%d",&List.children[i].num);
}
List.top=stasize;
list=&List;//应该是这附近出现问题
return (list);

}

int push(stack* p,Student x)
{
if(p->top-p->base==p->stacksize)
p->stacksize++;
p->top=p->top+1;
//p[statype->top]=*x;//可能有问题,关于结构体赋值的问题
//p[statype->top].name=x->name;
strcpy(p->children[p->top].name,x->name);
p->children[p->top].num=x->num;

}

int pop(Stack statype)
{
if(statype->top=statype->base)
exit(error);
statype->top=statype->top-1;
return 0;
}

int main(void)
{
stack* initstack(int stasize);
int push(stack* p,Student x);
//int pop(Stack statype);

stack* list=initstack(stack_size);
Student x;
x=(student*)malloc(sizeof(student));
strcpy(x->name,"liuyun");
push(list,x);
return 0;

}


  • 写回答

3条回答 默认 最新

  • haokeaiaheng 2016-04-10 09:58
    关注

    我应该是initstack返回值是出现了问题,不知道为什么,谢谢

    评论

报告相同问题?

悬赏问题

  • ¥20 iqoo11 如何下载安装工程模式
  • ¥15 本题的答案是不是有问题
  • ¥15 关于#r语言#的问题:(svydesign)为什么在一个大的数据集中抽取了一个小数据集
  • ¥15 C++使用Gunplot
  • ¥15 这个电路是如何实现路灯控制器的,原理是什么,怎么求解灯亮起后熄灭的时间如图?
  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 蓝桥杯单片机第十三届第一场,整点继电器吸合,5s后断开出现了问题
  • ¥15 file converter 转换格式失败 报错 Error marking filters as finished,如何解决?