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

 /*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. 变位词(0029)-swustoj

    变位词(0029)水题 变位词如果两个单词的组成字母完全相同,只是字母的排列顺序不一样,则它们就是变位词,两个单词相同也被认为是变位词.如tea 与eat , nic 与cin, ddc与dcd, a ...

  2. redis—操作基础

    内存数据库: 1.双击redis-server.exe =>启动2.双击redis-cli.exe =>打开管理控制台3.查看所有key keys *4.查看key类型 type myKe ...

  3. C# 中枚举的一点研究(跳过一些net坑的研究而已)

    之前一直使用Enum.Parse()将字符串转为枚举,没有深究,后面发现一个问题后对下面的Enum有了一个初步研究(.net 4.0).看下面代码. (留意,枚举类型是值类型,其值不能为Null,所以 ...

  4. 【原创】2、小程序域名配置之申请支持SSL(https)

    要把一个网站对接进小程序,一.网站的域名必须通过备案(ICP备案).在买域名的时候,各个域名服务商都有提供相应的备案平台,可以方便的提交备案.工信部官网:http://www.miitbeian.go ...

  5. openstack pike与ceph集成

    openstack pike与ceph集成 Ceph luminous 安装配置 http://www.cnblogs.com/elvi/p/7897178.html openstack pike 集 ...

  6. LVS+keepalived快速搭建测试环境

    #LVS+keepalived快速搭建测试环境 #LVS+keepalived快速搭建测试环境 #centos6 X64 # LVS 负载均衡模式:DR(直接路由) 192.168.18.31 mas ...

  7. toastr 通知提示插件

    table.sb-tb td,table.sb-tb th { padding: 5px 10px !important } jquery toastr 一款轻量级的通知提示框插件. 网页开发中经常会 ...

  8. 51Nod 2006 飞行员配对(二分图最大匹配)

    链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=2006 思路: 二分匹配 注意n m的关系 代码: #include ...

  9. zzuli 1817: match number 模拟

    1817: match number Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 199  Solved: 72 SubmitStatusWeb B ...

  10. Nginx负载均衡使用ip

    upstream test1{ server 192.168.1.213; server 192.168.1.37; } server { listen 80; # default backlog=2 ...