鱼C论坛

 找回密码
 立即注册
查看: 132|回复: 3

单链表

[复制链接]
发表于 2021-5-17 10:29:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

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

x
本帖最后由 孤世星辰 于 2021-5-17 11:59 编辑
  1. #define OK 1
  2. #define ERROR 0
  3. #define TRUE 1
  4. #define FALSE 0

  5. typedef int Status;

  6. // Status 是函数的类型,其值是函数结果状态代码,如OK
  7. // 初始条件:顺序线性表L已存在,1 <= i <= ListLength(L)
  8. // 操作结果:用e返回L中第i个数据元素的值
  9. Status GetElem(SqList L, int i, ElemType *e)
  10. {
  11.     if( L.length==0 || i<1 || i>L.length )
  12.     {
  13.         return ERROR;
  14.     }
  15.     *e = L.data[i-1];                                //不是说线性表位序是从1开始么,为什么这个给我感觉还是跟数组一样从0开始呢

  16.     return OK;
  17. }
复制代码

  1. /* 初始条件:顺序线性表L已存在,1<=i<=ListLength(L) */
  2. /* 操作结果:删除L的第i个数据元素,并用e返回其值,L的长度-1 */

  3. Status ListDelete(LinkList *L, int i, ElemType *e)
  4. {
  5.     int j;
  6.     LinkList p, q;                                //这样定义指针是不是有问题,定义指针不是*p么

  7.     p = *L;
  8.     j = 1;

  9.     while( p->next && j<i )
  10.     {
  11.         p = p->next;
  12.         ++j;
  13.     }

  14.     if( !(p->next) || j>i )
  15.     {
  16.         return ERROR;
  17.     }

  18.     q = p->next;
  19.     p->next = q->next;

  20.     *e = q->data;
  21.     free(q);

  22.     return OK;
  23. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2021-5-17 10:34:24 | 显示全部楼层
本帖最后由 孤世星辰 于 2021-5-17 11:59 编辑

好像懂了,位序说的是第几个元素,是我们按照1开始,但是这个顺序表其实还是跟数组一样的,下标是0开始
后面那个定义指针还是没看懂
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2021-5-17 20:18:39 From FishC Mobile | 显示全部楼层
大佬,数据结构视频中的课件在哪里找?(ppt)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2021-5-18 10:23:48 | 显示全部楼层
无极空间 发表于 2021-5-17 20:18
大佬,数据结构视频中的课件在哪里找?(ppt)

http://bbs.fishc.com/thread-95941-1-1.html
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1

GMT+8, 2021-6-23 16:37

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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