| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 843 人关注过本帖
标题:概念问题
只看楼主 加入收藏
ibiancheng
Rank: 1
等 级:新手上路
帖 子:148
专家分:0
注 册:2007-4-3
收藏
 问题点数:0 回复次数:4 
概念问题

Status InitStack(SqStack &s); //构造一个空栈
Status DestroyStack(SqStack &s); //销毁栈
Status ClearStack(SqStack &s);//清空栈
Status GetTop(SqStack s,SElemType &e);//取得栈顶元素
Status Push(SqStack &s,SElemType &e);//入栈
Status Pop(SqStack &s,SElemType &e); //出栈

Status InitStack(SqStack &s)
{
s.base=(SElemType *)malloc(sizeof(SElemType)*STACK_INIT_SIZE);
if(!s.base)
exit(OVERFLOW);
s.stacksize=STACK_INIT_SIZE;
s.top=s.base;
return OK;
}

Status DestroyStack(SqStack &s)
{
if(!s.base)
return ERROR;
free(s.base);
SqStack *p=&s;
free(p);
return OK;
}

Status ClearStack(SqStack &s)
{
if(!s.base)
return ERROR;
s.top=s.base;
return OK;
}

Status GetTop(SqStack s,SElemType &e)
{
if(StackEmpty(s))
return ERROR;
e=*--s.top;
return OK;
}

Status Push(SqStack &s,SElemType &e)
{
if(!s.base)
return ERROR;
if(StackLength(s)==s.stacksize)
{
s.base=(SElemType *)realloc(s.base,(s.stacksize+STACKINCREMENT)*sizeof(SElemType));
if(!s.base)
exit(OVERFLOW);
s.top=s.base+s.stacksize;
s.stacksize+=STACKINCREMENT;
}
*s.top++=e;
return OK;
}

Status Pop(SqStack &s,SElemType &e)
{
if(StackEmpty(s))
return ERROR;
e=*--s.top;
return OK;
}



上面这些函数的参数中都有"&",不清楚是引用调用还是取地址(感觉是取地址),本人对这方面(用参数返回函数中值问题)比较迷惑,希望达人能给点这方面全面的资料(最好具体点),解释什么的,在这里先谢谢了!

搜索更多相关主题的帖子: 概念 
2007-11-06 15:23
ibiancheng
Rank: 1
等 级:新手上路
帖 子:148
专家分:0
注 册:2007-4-3
收藏
得分:0 

来个人指点指点呀。。。。。


执著的信念,坚定的自信,勤奋的努力才是通向成功的捷径! !!
2007-11-06 21:33
succubus
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:4
帖 子:635
专家分:1080
注 册:2007-10-7
收藏
得分:0 

指的是引用


[url=http:///view/aDU1]/image/aDU1.gif" border="0" />[/url]
2007-11-06 21:38
ibiancheng
Rank: 1
等 级:新手上路
帖 子:148
专家分:0
注 册:2007-4-3
收藏
得分:0 

先谢谢
你是说引用调用?那下面的情况呢?我其实是想问下面这种情况的!

void Pop2(LinkStack *head,int *e)
{//出栈,函数返回值由参数返回
Node *pre;
pre=head->top;
*e=pre->data;
head->top=pre->next;
if(pre->next==NULL)
head->base=NULL;
free(pre);
}


调用时 Pop2(head,&e);

这里应该不是调用吧。
我看什么课件上说,这是用指针返回函数值,实参是变量的地址。是不是这个情况?

我在老潭的书上怎么没看见这个呢,还是我看走眼了???



[此贴子已经被作者于2007-11-7 17:57:44编辑过]


执著的信念,坚定的自信,勤奋的努力才是通向成功的捷径! !!
2007-11-07 17:54
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
以下是引用ibiancheng在2007-11-7 17:54:30的发言:

先谢谢
你是说引用调用?那下面的情况呢?我其实是想问下面这种情况的!

void Pop2(LinkStack *head,int *e)
{//出栈,函数返回值由参数返回
Node *pre;
pre=head->top;
*e=pre->data;
head->top=pre->next;
if(pre->next==NULL)
head->base=NULL;
free(pre);
}


调用时 Pop2(head,&e);//这里是去地址

这里应该不是调用吧。
我看什么课件上说,这是用指针返回函数值,实参是变量的地址。是不是这个情况?

我在老潭的书上怎么没看见这个呢,还是我看走眼了???





倚天照海花无数,流水高山心自知。
2007-11-17 15:56
快速回复:概念问题
数据加载中...
 
   



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

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