| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1118 人关注过本帖
标题:创建链表的一个问题
取消只看楼主 加入收藏
Q309705759
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2005-11-22
收藏
 问题点数:0 回复次数:0 
创建链表的一个问题

创建链表的一个问题:
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#define ok 1
#define error 0
#define overflow 0
typedef struct lnode
{
int data;
struct lnode *next;
}lnode,*linklist;


int initlist_l(linklist &l)
{
l=(linklist)malloc(sizeof(lnode));
if(!l)
exit(overflow);
l->next=NULL;
return ok;
}

////////////////////////////////////////////////

int createlist_l(linklist &l,int n)
{
linklist p,q;
int i;
printf("input the data:");
q=l;
for(i=0;i<n;i++)
{p=(linklist)malloc(sizeof(lnode));
scanf("%d",&p->data);
p->next=q->next;
q->next=p;
q=p;
}
return ok;
}

最后面几行中有
q->next=p;
q=p;
应该可以了啊,前面的p->next=q->next;有什么含义。盼望解答`````






全部代码如下:
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#define ok 1
#define error 0
#define overflow 0
typedef struct lnode
{
int data;
struct lnode *next;
}lnode,*linklist;


int initlist_l(linklist &l)
{
l=(linklist)malloc(sizeof(lnode));
if(!l)
exit(overflow);
l->next=NULL;
return ok;
}

////////////////////////////////////////////////

int createlist_l(linklist &l,int n)
{
linklist p,q;
int i;
printf("input the data:");
q=l;
for(i=0;i<n;i++)
{p=(linklist)malloc(sizeof(lnode));
scanf("%d",&p->data);
p->next=q->next;
q->next=p;
q=p;
}
return ok;
}

int traverselist_l(linklist l)
{
linklist p;
p=l->next;
while(p)
{
printf("%d",p->data);
p=p->next;

}
return ok;
}

void main()
{
int n;
linklist l;
initlist_l(l);
printf("输入表的长度:");
scanf("%d",&n);
createlist_l(l,n);
printf("输出数据:");
traverselist_l(l);
}


搜索更多相关主题的帖子: 链表 int lnode linklist overflow 
2005-11-22 10:39
快速回复:创建链表的一个问题
数据加载中...
 
   



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

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