找回密码
 注册
关于网站域名变更的通知
查看: 532|回复: 5
打印 上一主题 下一主题

建立单链线性表

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2016-7-13 15:22 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
通常,在设有“指针”数据类型的高级语言中均存在与其相应的过程或函数。假设p和q是LinkList型的变量,则执行p=(LinkList)malloc(sizeof(L Node))的作用是由系统生成的一个LNode型的结点,同时将该结点的起始位置赋给指针变量p,反之,执行free(q)的作用是由系统回收一个LNode型的结点,回收后的空间可以备作再次生成结点时用。因此,单链表和顺序存储结构不同,它是一种动态结构。整个可用存储系统空间可为多个链表共同享用,每个链表占用的空间不需预先分配划定,而是可以由系统应需求即时生成。因此,建立线性表的链式存储结构的过程就是一个动态生成链表的过程。即从“空表”的初始状态起,依此建立个元素结点,并逐个插入链表。  P1 _0 T* N  {" _
void CreateList_L(LinkList &L,int n){% J) I' n( f% x7 r  {: |
//逆位序输入n个元素的值,建立带表头的单链线性表L。
8 u% Y( d& l- V3 I              L=(LinkList)malloc(sizeof(LNode));
4 p& F8 l( X- C6 r- }+ P0 n              L->next=NULL;//先建立一个带头结点的单链表
. w/ F3 L8 Q1 F( l; m& a              for(i=n;i>0;--i){' W: S$ u  M* F' N8 W
              p=(LinkList)malloc(sizeof (LNode));//生成新结点% g0 z: r( i! R7 h, `  U9 P
              scanf(&p->data);           //输入元素值) Z$ y4 O6 B; p$ }, s) o
              p->next=L->next;L->next=p;//插入到表头- M5 q9 H/ e& P6 c8 K
       }) q6 {2 k0 w9 ?& x# r6 L$ D
}//CreateList_L

该用户从未签到

2#
发表于 2016-7-14 08:54 | 只看该作者
谢谢楼主,一步步来,学习中……
6 X9 |. N+ m, p. t

该用户从未签到

3#
发表于 2016-7-14 14:28 | 只看该作者
谢谢楼主,一步步来,学习中……
/ N0 x- y5 W/ k

该用户从未签到

4#
发表于 2016-8-3 15:54 | 只看该作者
支持一下,很不错哦!1 R$ n- m" |7 H# O

该用户从未签到

5#
发表于 2016-8-4 14:50 | 只看该作者
谢谢分享,必须赞一个~
! l. y4 R9 h  n$ Q, Z( ~+ A

该用户从未签到

6#
发表于 2016-8-9 10:20 | 只看该作者
看贴学心得,回贴是美德
) I% k1 S' ?" ^* D  i, ~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-24 00:10 , Processed in 0.140625 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表