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

大家好!初次在论坛上求助,希望得到大家的帮助!
我最近在学习数据结构,下面是关于线形表的程序。
在初始化线性表函数中,函数写成void InitList(SqList *&L)就正确,
如果函数写成void InitList(SqList *L);就错误
请问大家void InitList(SqList *L);与void InitList(SqList *&L);有什么区别?
在这位什么不能写成void InitList(SqList *L);?
谢谢!
#define MaxSize 50
typedef char ElemType;
typedef struct
{
ElemType elem[MaxSize];
int length;
}SqList;

void InitList(SqList *&L);//初始化线性表
int ListInsert(SqList *L,int i,ElemType e);
void DispList(SqList *L);


void main()
{
SqList *L;
ElemType e;
printf("初始化顺序表L\n");
InitList(L);
}
void InitList(SqList* &L)
{
L=(SqList *)malloc(sizeof(SqList));
L->length=0;
}

搜索更多相关主题的帖子: 数据结构 线性 
2007-05-16 21:16
taojingwen
Rank: 1
等 级:新手上路
帖 子:53
专家分:0
注 册:2007-5-5
收藏
得分:0 
回复:(weishanhu03)数据结构中线性表的问题,请大家...
*和&是互补的,相当于+和-。
*&L实际上是等于L的。
你再看看书。

I Believe I Can Fly
2007-05-16 21:43
xiawenjin
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2007-5-13
收藏
得分:0 
有好的c书吗?我书上怎么都没有这些东东啊?有书上传!!OK?
2007-05-16 22:35
leeco
Rank: 4
等 级:贵宾
威 望:10
帖 子:1029
专家分:177
注 册:2007-5-10
收藏
得分:0 
L的类型是SqList*
InitList函数期望修改实参L的值,所以不能采用值传递,需要使用引用传递,SqList*& 应该理解为SqList*类型的引用类型。


题外话:
定义指针的时候可以使用
int *p;
也可以使用
int* p;
后一种写法表现了一些C/C++程序员期望将int*看作一种类型,而事实上是没有这种类型的,下面的语句可以表明这一点
int* p,q;
定义了一个指针变量p,和一个整型变量p
即便如此,很多时候将指针视作一个类型是更自然的,更容易理解的。
2007-05-16 22:43
快速回复:数据结构中线性表的问题,请大家看看!
数据加载中...
 
   



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

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