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

建立单链线性表

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
通常,在设有“指针”数据类型的高级语言中均存在与其相应的过程或函数。假设p和q是LinkList型的变量,则执行p=(LinkList)malloc(sizeof(L Node))的作用是由系统生成的一个LNode型的结点,同时将该结点的起始位置赋给指针变量p,反之,执行free(q)的作用是由系统回收一个LNode型的结点,回收后的空间可以备作再次生成结点时用。因此,单链表和顺序存储结构不同,它是一种动态结构。整个可用存储系统空间可为多个链表共同享用,每个链表占用的空间不需预先分配划定,而是可以由系统应需求即时生成。因此,建立线性表的链式存储结构的过程就是一个动态生成链表的过程。即从“空表”的初始状态起,依此建立个元素结点,并逐个插入链表。
! q5 m; ~/ S/ j+ s" F1 {& [- V4 ~void CreateList_L(LinkList &L,int n){" W9 s: {: f9 U/ e- k: x
//逆位序输入n个元素的值,建立带表头的单链线性表L。3 \9 w/ w$ H0 \% O2 v; W* |
              L=(LinkList)malloc(sizeof(LNode));
8 s0 ]& g. _8 i* ^8 s              L->next=NULL;//先建立一个带头结点的单链表
& P& G$ K% h% c$ H6 P& w              for(i=n;i>0;--i){  \: H1 N( Q0 ^& G
              p=(LinkList)malloc(sizeof (LNode));//生成新结点! b: p: `3 N8 z: \! x
              scanf(&p->data);           //输入元素值
0 Z6 o- v5 g3 o9 Y6 F. U+ h              p->next=L->next;L->next=p;//插入到表头0 h  M5 j/ F8 x: i, T( G7 V
       }
. `: o, C6 |+ g) R6 m}//CreateList_L

该用户从未签到

2#
发表于 2016-7-14 08:54 | 只看该作者
谢谢楼主,一步步来,学习中……
1 H  z) g5 A! u' N

该用户从未签到

3#
发表于 2016-7-14 14:28 | 只看该作者
谢谢楼主,一步步来,学习中……2 M+ c  e+ y! t6 Y( l) i" r) D/ T

该用户从未签到

4#
发表于 2016-8-3 15:54 | 只看该作者
支持一下,很不错哦!1 ]8 F4 u( C$ ]; }" c1 ]

该用户从未签到

5#
发表于 2016-8-4 14:50 | 只看该作者
谢谢分享,必须赞一个~
# ~. n9 T5 v- v5 G* F

该用户从未签到

6#
发表于 2016-8-9 10:20 | 只看该作者
看贴学心得,回贴是美德
. t; R3 o5 y* G+ R% ~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-10-12 05:21 , Processed in 0.125000 second(s), 23 queries , Gzip On.

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

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

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