这两天在复习C语言的知识,为了给下个阶段学习OC做准备,以下的代码的编译运行环境是Xcode5.0版本,写篇博文把昨天复习的C语言有关链表的知识给大家分享一下,以下是小菜自己总结的内容,代码也是按照自己的思路所编写的,有不足之处还请大牛们批评指教。

  确切的说链表属于数据结构中线性表中的内容,在链表中存储的内容是按线性排列的,就像是一条线把所要存的数据串起来,可以把链表类比成一串珠子,数据就是一个个的珠子,数据间的next指针就相当于穿珠子的线。

  链表操作的时间复杂度: 往链表中插入数据的时间复杂度为O(1)。

  想真正的理解链表及在C语言中的表示方法的前提是理解C语言中的指针和结构体,闲话少说,进代码才是关键,代码中基本上都有注释

  1.用结构体定义链表的节点

  1. //定义链表中的节点
  2. typedef struct node{
  3. //存储数据
  4. int data;
  5. //指向下一个节点
  6. struct node *next;
  7. }Node;

  2.定义链表的整体结构,存放链表的节点和链表中的信息

  1. //定义链表结构
  2. typedef struct {
  3. //存放头节点
  4. Node *head;
  5. //记录节点的个数
  6. int count;
  7. }List;

  

  3.链表的初始化,给链表分配头结点,节点个数初始化为0

  1. /************************************************
  2. *功能:初始化链表,分配头结点,结点个数为0
  3. *参数:链表指针
  4. *作者:Mr.li
  5. *日期:14-07-23
  6. ************************************************/
  7. void initLinkList(List *list)
  8. {
  9. //给头节点分配内存
  10. list->head = malloc(sizeof(Node));
  11. //头结点的下一个节点为空
  12. list->head->next = NULL;
  13. //总节点个数为0
  14. list->count = ;
  15. }

  4.建立单项链表,这里为了简单起见,把要存入数据先存入到array中,下面我是用逆序的方法来创建链表的,是从head节点后插入数据,也可以用顺序建链表,从链表的后面插入数据

  1. /************************************************
  2. *功能:逆序建立链表,从头结点后插入
  3. *参数:链表指针
  4. *作者:Mr.li
  5. *日期:14-07-23
  6. ************************************************/
  7. void createLinkList(List *list)
  8. {
  9. //建立链表用到的数据
  10. ] = {,,,,,,,,,};
  11. //临时节点指针用于分配节点内存
  12. Node *p;
  13. ; i < ; i++)
  14. {
  15. //给新的节点分配内存
  16. p = (Node *)malloc(sizeof(Node));
  17. //给新节点赋值
  18. p->data = a[i];
  19. //把值加入到头节点后面,逆序建立链表
  20. p->next = list->head->next;
  21. list->head->next = p;
  22. //链表节点个数加一
  23. list->count++;
  24. }
  25. }

  5.为了方便查看链表中的值,需要一个打印链表中的数据的函数

  1. /************************************************
  2. *功能:打印链表中的值
  3. *参数:链表指针
  4. *作者:Mr.li
  5. *日期:14-07-23
  6. ************************************************/
  7. void printList(List *list)
  8. {
  9. //临时节点指针变量
  10. Node *p;
  11. //从头开始遍历
  12. p = list->head->next;
  13. while (p != NULL)
  14. {
  15. //自定义的输出整的函数
  16. print(p->data);
  17. p = p->next;
  18. }
  19. putchar('\n');
  20. }

  6.查询元素在链表中对于的位置

  1. /************************************************
  2. *功能:查找链表中指定值的位置,有的返还其位置,无,返还-1
  3. *参数:链表指针,要查找的值
  4. *作者:Mr.li
  5. *日期:14-07-23
  6. ************************************************/
  7. int search(List *list, int obj)
  8. {
  9. //定义游标指针
  10. Node *p;
  11. //标记值的位置
  12. ;
  13. p = list->head->next;
  14. while (p != NULL)
  15. {
  16. local ++;
  17. if (p->data == obj)
  18. {
  19. //返回值的位置
  20. return local;
  21. }
  22. p = p->next;
  23. }
  24. //值不存在返回-1
  25. ;
  26. }

  7.删除链表中的相应的数据

  1. /************************************************
  2. *功能:删除链表中的值
  3. *参数:链表指针,要删除的值
  4. *作者:Mr.li
  5. *日期:14-07-23
  6. ************************************************/
  7. void delete(List *list, int obj)
  8. {
  9. //查询要删除的元素是否在链表中,有返还相应的位置,没有则返还-1
  10. int flag = search(list, obj);
  11.  
  12. //判断值的合法性
  13. )
  14. {
  15. printf("没有要删除的值!\n");
  16. }
  17. else
  18. {
  19. //定义两个辅助游标指针
  20. Node *p, *q;
  21.  
  22. //给q,p赋值
  23. q= list->head;
  24. p = list->head->next;
  25.  
  26. //循环查找相应的值并删除
  27. while (p != NULL)
  28. {
  29. if (p->data == obj)
  30. {
  31. q->next = p->next;
  32. p->next = NULL;
  33. free(p);
  34. break;
  35. }
  36. q = p;
  37. p = p->next;
  38. }
  39. }
  40. }

  8.往链表中插入数据

  1. /************************************************
  2. *功能:往指定的位置后插入相应的值
  3. *参数:链表指针,插入的位置,插入的值
  4. *作者:Mr.li
  5. *日期:14-07-23
  6. ************************************************/
  7. void insert(List *list, int local, int number)
  8. {
  9. ;
  10. //判断值的合法性
  11. if(count > list->count)
  12. {
  13. printf("你输入的值不合法\n");
  14. }
  15. else
  16. {
  17. //定义游标指针,指向链表的头结点
  18. Node *p = list->head;
  19. while (count != local) {
  20. p++;
  21. count++;
  22. }
  23.  
  24. //分配新的结点并给新的结点赋值
  25. Node *q = (Node *) malloc(sizeof(Node));
  26. q->data = number;
  27. q->next = NULL;
  28.  
  29. //插入新的结点
  30. q->next = p->next;
  31. p->next = q;
  32. }
  33.  
  34. }

  以上是小菜学习链表的代码了,给大家分享一下!!

  

C语言之链表的更多相关文章

  1. C语言习题 链表建立,插入,删除,输出

    Problem B: C语言习题 链表建立,插入,删除,输出 Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 222  Solved: 92 [Subm ...

  2. YTU 2430: C语言习题 链表建立,插入,删除,输出

    2430: C语言习题 链表建立,插入,删除,输出 时间限制: 1 Sec  内存限制: 128 MB 提交: 576  解决: 280 题目描述 编写一个函数creatlink,用来建立一个动态链表 ...

  3. 关于c语言单项链表尾添加

    犹豫了几天,看了很多大牛写的关于c语言链表,感触很多,终于下定决心,把自己对于链表的理解随之附上,可用与否,自行裁夺.由于作者水平有限也是第一次写,不足之处,竭诚希望得到各位大神的批评指正.制作不易, ...

  4. C语言之链表list

    #include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h& ...

  5. C语言:链表实现的一个实例

    问题:写一个程序输入你一年看过的所有电影以及每部电影的各种信息(简化问题:每部电影只要求输入片名和评价) 链表实现: #include<stdio.h> #include<stdli ...

  6. C语言单链表实现19个功能完全详解

    谢谢Lee.Kevin分享了这篇文章 最近在复习数据结构,想把数据结构里面涉及的都自己实现一下,完全是用C语言实现的. 自己编写的不是很好,大家可以参考,有错误希望帮忙指正,现在正处于编写阶段,一共将 ...

  7. (转)c语言_链表实例讲解(两个经典例子)

    建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. #include <stdio.h>#include <stdlib.h> struct grade {    ...

  8. Javascript模仿C语言的链表实现(增删改查),并且使用控制台输入输出

    Js新手最近在研究Js数据结构,刚好看到链表实现这一块儿,觉得有些资料和自己理解的有冲突,于是借着自己以前一点点C语言的基础,用Javascript模仿了C的链表实现,并且用了process.stdi ...

  9. c语言_链表实例讲解(两个经典例子)

    建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. demo1 // lianbiao.cpp : Defines the entry point for the console app ...

随机推荐

  1. JS代码将数据导入Excel

    如果在别的浏览器中无法导入,尝试用IE浏览器 function AutomateExcelall(){try { oXL = new ActiveXObject('Excel.Application' ...

  2. div样式text-align在子元素缩进不规范的情况下,chrome出现的问题(貌似结果是inline-block导致的)

    在调css的时候,发现居然有firefox实现效果完整而chrome出现问题的情况: 详细情况:segmentfault1 segmentfault2 全文表达: <html><he ...

  3. XNA游戏编程等

    XNA游戏编程:http://shiba.hpe.sh.cn/jiaoyanzu/WULI/soft/xna.aspx?classId=4 表示没学过XNA,但感觉还是很不错的,给学XNA的童鞋们参考 ...

  4. Xamarin的不归路-ios模拟器调整窗口大小

    ios模拟器调整窗口大小:

  5. HDU2842 矩阵乘法

    Chinese Rings Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  6. git上传文件出错的时候

    $ git pull --rebase origin master 运行这个基本OK!

  7. 对象的this引用

    Java中的this关键字总是指向调用该方法的对象.根据this出现位置的不同,this作为对象的默认引用有两个功能: 1.构造器中引用该构造器正在初始化的对象. 2.在方法中引用调用该方法的对象. ...

  8. SQL语句 多表基本操作

    创建四张表学生表:学号(Sno).姓名(Sname).性别(Ssex).年龄(Sage)教师表:教师编号(Tno).教师姓名(Tname)课程表:课程编号(Cno).课程名(Cname).教师编号(T ...

  9. Third Day(上班第四天):Android开发环境配置问题相关

    换公司新电脑了,重新安装Android开发环境,并配置,具体流程如下:1.百度JDK,访问Oracle官网:http://www.oracle.com/technetwork/java/javase/ ...

  10. 移动Web触控事件总结

    移动web风风火火几多年,让我这个在Pc端漂流的前端er不免心生仰慕,的确入行几多年,也该是时候进军移动web了.移动web中踩到的第一个坑就是事件问题,所以在吸取众大神的经验后,特作总结以示后来者. ...