今天搞了一个多小时,头是疼的,应该是没休息好吧,学习了数据结构这一节,感觉收益良多,下面贴上代码和心得:

 /*24_链表创建和链表遍历算法的演示*/
 # include <stdio.h>
 # include <malloc.h>
 # include <stdlib.h>

 typedef struct Node
 {
     int data;//数据域
     struct Node * pNext;//指针域
 }NODE, *PNODE;//NODE等价于struct Node

               //函数声明
 PNODE create_list(void);
 void traverse_list(PNODE pHead); 

 int main(void)
 {
     PNODE pHead = NULL;//等价于 struct Node * pHead = NULL;把首节点的地址赋值给pHead(在一个链表中首节点和尾节点后面都是NULL,没有其他元素)
                        //PNODE 等价于struct Node *
     pHead = create_list();
     traverse_list(pHead);

     ;
 }

 //创建地址类型的地址,因为create_list 这个函数是要返回的地址
 //功能就是把头节点的地址返回,最终才能头节点才能指向一个链表
 PNODE create_list(void)
 {
     int len;//存放有效节点的个数
     int i;
     int val;//用来临时存放用户熟入的节点是值

 //前面说过只要是找到头节点,对于链表的操作就方便了,所以在这里我们首先先定义头节点
     PNODE pHead = (PNODE)malloc(sizeof(NODE));//定义头节点(不存放有效数据)
     if (NULL == pHead) //如果指针指向为空,则动态内存分配失败
     {
         printf("分配失败,程序终止!\n");
         exit(-);
     }
     PNODE pTail = pHead; //pHead 是指向头节点的,如果用户是输入节点的个数是0,那么只有一个“头节点”
     pTail->data = NULL; //此时把pHead 赋值给pTail,则就合理l,然后指针域为空(和初始化差不多...)

     printf("请您输入要生成链表节点的个数:len = ");
     scanf("%d", &len);
     ; i < len; i++)
     {
         printf();
         scanf("%d", &val);
         PNODE pNew = (PNODE)malloc(sizeof(NODE));//创建新节点,使之指针都指向每一个节点(循环了len次)
         if (NULL == pNew) //如果指针指向为空,则动态内存分配失败
         {
             printf("分配失败,程序终止!\n");
             exit(-);
         }
         /*

         pNew->data = val;//一个临时的节点
         pHead->pNext = pNew;//把pNew挂到pHead上
         pNew->pNext=NULL; //这个临时的节点最末尾是空

         */

         //上面/**/注释掉的这行代码是有问题的,上面注释掉的代码的含义是分别把头节点后面的节点都挂在头节点上,
         //导致头节点后面的节点的指针域丢失,而我们想的是只是把第一个节点挂在头节点上,后面的依次进行,即把第二个
         //节点挂在第一个节点的指针域上,依次类推,很明显上面所注释掉的代码是实现不了这个功能的

         //下面是改进之后的
         pNew->data = val; //把有效数据存入pNEW
         pTail->pNext = pNew; //把pNew 挂在pTail的后面(也就是pTail指针域指向,依次串起来)
         pNew->pNext = NULL;//把pNew的指针域清空
         pTail = pNew;   //在把pNew赋值给pTai,这样就能循环,实现依次连接(而我们想的是只是把第一个节点挂在头节点上,后面的依次进行,即把第二个
                         //节点挂在第一个节点的指针域上)
     }
     return pHead;
 }

 //遍历函数并不需要返回值,参数还是要有的,要不然怎么知道是对哪个对象进行的遍历!
 //还是定义指针变量 PNODE pHead 因为 traverse_list(pHead)  调用的是地址

 /*
 链表的遍历写法的整体思路:
     1. 定义一个指针变量p指向第一个有效的节点
     2.判断这个节点的指针域是不是为空(如果不是就不是最后一个)
     3.不为空就输出此节点的有效数据,并且p-pNext来指向下一个节点(不能用p++哦!)
     4.如果为空的话,说明到来尾节点
 */

 void traverse_list(PNODE pHead)//怎样遍历,是不能像以前一样用数组的,以为数组是连续的,这里不连续
 {
     PNODE p = pHead->pNext;

     while (NULL != p)
     {
         printf("%d ", p->data);
         p = p->pNext;
     }
     printf("\n");
 }

运行截图:

吟诗一首:

    精神经百炼,锋锐坚不挫。 ——刘过

链表创建和链表遍历算法的演示_C语言的更多相关文章

  1. 单链表的插入伪算法和用C语言创建单链表,并遍历

    非循环单链表插入结点伪算法讲解 q插入p之后的伪算法:第一种表示方法:r = p->pNext; // p->pNext表示的是所指向结点的指针域,指针域又是指向下一个结点的地址p-> ...

  2. 「C语言」单链表/双向链表的建立/遍历/插入/删除

    最近临近期末的C语言课程设计比平时练习作业一下难了不止一个档次,第一次接触到了C语言的框架开发,了解了View(界面层).Service(业务逻辑层).Persistence(持久化层)的分离和耦合, ...

  3. 【数据结构与算法】(二) c 语言链表的简单操作

    // // main.c // testLink // // Created by lan on 16/3/6. // Copyright © 2016年 lan. All rights reserv ...

  4. 链表习题(2)-一个集合用带头结点的单链表L表示,编写算法删除其值最大的结点。

    /*一个集合用带头结点的单链表L表示,编写算法删除其值最大的结点.*/ /* 算法思想:使用pre,p,premax,max四个指针,pre和p进行比较,premax和max进行最后的删除操作 通过遍 ...

  5. Project 1 :创建链表与显示链表

    目标:创建一个链表,并将链表输出.结构体中包括学号与分数.链表以输入学号为0作为结束.输出模版为 No.学号 Score:分数 输入样例: 10101 98 10102 97 10103 100 10 ...

  6. [PHP] 数据结构-链表创建-插入-删除-查找的PHP实现

    链表获取元素1.声明结点p指向链表第一个结点,j初始化1开始2.j<i,p指向下一结点,因为此时p是指向的p的next,因此不需要等于3.如果到末尾了,p还为null,就是没有查找到 插入元素1 ...

  7. [算法]在单链表和双链表中删除倒数第k个结点

    题目: 分别实现两个函数,一个可以删除单链表中倒数第K个节点,另一个可以删除双链表中倒数第K个节点. 要求: 如果链表长度为N,时间复杂度达到O(N),额外空间复杂度达到O(1). 解答: 让链表从头 ...

  8. Python -二叉树 创建与遍历算法(很详细)

    树表示由边连接的节点.它是一个非线性的数据结构.它具有以下特性. 一个节点被标记为根节点. 除根节点之外的每个节点都与一个父节点关联. 每个节点可以有一个arbiatry编号的chid节点. 我们使用 ...

  9. c++ LeetCode (网易面试题和链表以及树篇) 五道算法例题代码详解(三)

    原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/11209807.html 一.1道网易c++的面试题 我当时第一时间的解答方案 #include ...

随机推荐

  1. mysql数据库表卡死解决方法

    ---恢复内容开始--- 问题引起原因: 由于在执行大量插入操作的时候意外终止程序之后, MySQl的线程并没有被终止,导致表不能打开和操作 -  解决思路就是找到等待的线程并kill -- 查看所有 ...

  2. input取值区间实例

    前端开发中经常会遇到 input 取值区间的需求,比如搜索的时候,价格区间,积分值区间 大致的需求为 input 的值必须是正整数,第二个 input 的值必须大于第一个 DOM结构如下: <d ...

  3. C# tostring

    GUID: 即Globally Unique Identifier(全球唯一标识符) 也称作 UUID(Universally Unique IDentifier) . GUID是一个通过特定算法产生 ...

  4. ip地址与整数相互转换

    一.将ip地址转成long数值 将IP地址转化成整数的方法如下: 1.通过String的split方法按.分隔得到4个长度的数组 2.通过左移位操作(<<)给每一段的数字加权,第一段的权为 ...

  5. Python之文件的基本操作

    在python中,对文件的基本操作一共有如下四种: 1.打开文件 file_obj = open("文件路径","模式") 常用的打开文件模式有: r:以只读方 ...

  6. Windows系统重装

    http://www.ishuo.cn/show/76437.htmlhttp://jingyan.baidu.com/article/d8072ac45d4f60ec95cefdaa.html

  7. 【MAVEN】maven系列--pom.xml标签详解

    pom文件作为MAVEN中重要的配置文件,对于它的配置是相当重要.文件中包含了开发者需遵循的规则.缺陷管理系统.组织.licenses.项目信息.项目依赖性等.下面将重点介绍一下该文件的基本组成与功能 ...

  8. Serializable 都这么牛逼了,Parcelable 还要你何用?

    一些闲聊 距离上一篇文章似乎又是很久了,看起来也没有很多反馈,催更就更不用说了.哈哈,放弃了. 话说最近公司在招聘一批至少 5 年开发经验的 Android 开发工程师,我也是忙开了花,激动得不行呀. ...

  9. mysql分区分表

    为毛要分表和分区,,,,所有数据库的通病,文件越大,性能越低...那问题就来了.数据越多文件越大...无解?哎,所以说知道 为毛要分区了吧!那分表又是毛线?分表就是把一张表拆分成若干表,,,根据情况常 ...

  10. 【NOIP2009提高组】最优贸易

    https://www.luogu.org/problem/show?pid=1073 如果他想在i点卖出,那么就要在从1点出发到i点的路径里找个最便宜的买入,用Bellman-Ford求出这样最便宜 ...