马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
void CreateList_L(LinkList *L, int n) { // 算法2.11
// 逆位序输入(随机产生)n个元素的值,建立带表头结点的单链线性表L
LinkList p;
int i;
srand(time(0));
(*L) = (LinkList)malloc(sizeof(LNode));
(*L)->next = NULL; // 先建立一个带头结点的单链表
for (i=0; i<n; i++) {
p = (LinkList)malloc(sizeof(LNode)); // 生成新结点
p->data = rand()%100+1; // 改为一个随机生成的数字
p->next = (*L)->next;
(*L)->next = p; // 插入到表头
}
} // CreateList_L
这里面为什么是(*L)->next 在结构体中不是(*L).next 的引用吗 ?
还有第二个问题 p = (LinkList)malloc(sizeof(LNode)) 这个中 被强制转换后 不是指针了 怎么可以赋值给指针变量P呢 malloc没有被强制转换返回的是viod*类型的 相当于一个地址。我想应该是p = (LinkList*)malloc(sizeof(LNode))
在这句(*L) = (LinkList)malloc(sizeof(LNode)) 中(*L) 表示的不是指针了 因为有个* 是取指针L所指向的内容或者赋值给它 经过强制转换 2边类型一样可以赋值 但是在p = (LinkList)malloc(sizeof(LNode)) 这个中 按那样分析就说不通了。。这到底那里出错了呀?????????????????? |