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

这个是编程中国上《链表的c语言实现》这篇文章里的一个例子。代码中用红色标识的
h->name[0]='\o';
h->link=NULL;
p=h;///把p指向h,p变h也跟着变????当p->link=s时那h->link也等于s咯??????

#include <stdio.h>
#include <malloc.h> /*包含动态内存分配函数的头文件*/
#define N 10 /*N为人数*/
typedef struct node
{
char name[20];
struct node *link;
}stud;
stud * creat(int n) /*建立单链表的函数,形参n为人数*/
{
stud *p,*h,*s; /* *h保存表头结点的指针,*p指向当前结点的前一个结点,*s指向当前结点*/
int i; /*计数器*/
if((h=(stud *)malloc(sizeof(stud)))==NULL) /*分配空间并检测*/
{
printf("不能分配内存空间!");
exit(0);
}
h->name[0]='\0'; /*把表头结点的数据域置空*/
h->link=NULL; /*把表头结点的链域置空*/
p=h; /*p指向表头结点*/
for(i=0;i<n;i++)
{
if((s= (stud *) malloc(sizeof(stud)))==NULL) /*分配新存储空间并检测*/
{
printf("不能分配内存空间!");
exit(0);
}
p->link=s; /*把s的地址赋给p所指向的结点的链域,这样就把p和s所指向的结点连接起来了*/
printf("请输入第%d个人的姓名",i+1);
scanf("%s",s->name); /*在当前结点s的数据域中存储姓名*/
s->link=NULL;
p=s;
}
return(h);
}

main()
{
int number; /*保存人数的变量*/
stud *head; /*head是保存单链表的表头结点地址的指针*/
number=N;
head=creat(number); /*把所新建的单链表表头地址赋给head*/
}

搜索更多相关主题的帖子: c语言 编程 color 中国 
2006-11-04 09:13
wyzn12
Rank: 1
等 级:新手上路
帖 子:129
专家分:0
注 册:2006-10-28
收藏
得分:0 
p=h;
把p指向h,应该是h变p也变,p变h不变
当p->link=s时那h->link也等于s咯??????
当p==h的时候p->link=s时那h->link也等于s,如果p变了
如:p=h->link,那么p->link=s时那h->link就不等于s

新王登基,血流成河!
2006-11-04 10:25
C语言学习者
Rank: 4
等 级:贵宾
威 望:13
帖 子:1278
专家分:0
注 册:2006-9-26
收藏
得分:0 
写得很乱

谁有强殖装甲第二部,可以Q我460054868
2006-11-04 12:58
快速回复:一个指针的问题
数据加载中...
 
   



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

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