C语言单链表的算法之遍历节点

一:什么是遍历

(1)遍历就是把单链表中的各个节点挨个拿出来,就叫遍历

(2)便利的要点:一是不能遗漏,二是不能重复追求效率

二:如何遍历单链表

(1)分析一个数据结构如何遍历,关键是分析这个数据结构本身的特点。然后根据本身特点来制定它的遍历算法

(2)单链表的特点就是由很多个节点组成,头指针+头节点为整个链表的起始,最后一个节点的特征是它内部的pnext指针的值为null。从起始到结尾中间由各个节点内部的pnext指针来挂接。由起始到结尾的路劲只有一条,这个特点就决定了它的遍历算法

(3)遍历方法:从头指针+头节点开始,顺着链表挂接指针依次访问链表的各个节点,取出这个节点的数据,然后再往下一个节点,直到最后一个数据结束返回

三:编程实战

cpp 复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

//构建一个链表节点
struct node
{

    int datas;
    struct node *pNEXT;


};

/****************************************
函数名:create
作用:创建一个链表节点
返回值:p 指针,指针指向本函数创建的一个节点的首地址
参数:
****************************************/
struct node *create(int a)
{


    struct node *p = (struct node *)malloc(sizeof(struct node));

    if(NULL == p)
        {
            printf("malloc error!\n");

            return NULL;

        }

      memset(p,0,sizeof(struct node));  
      //bzero(p,sizeof(struct node));

      p->datas = a;
      p->pNEXT = NULL;


      return p;


}


/****************************************
函数名:insert_tail
作用:从链表尾部插入节点
返回值:无
参数:phead:链表的头指针 new:插入的新节点指针
****************************************/
void insert_tail(struct node *phead,struct node *new)
{

    struct node *p = phead;
    int cat = 0;
    while(NULL !=  p->pNEXT)
        {


            p = p->pNEXT;
            cat++;

        }

        p->pNEXT = new;
        phead->datas = cat +1;


}


/****************************************
函数名:insert_head
作用:从链表头部插入节点
返回值:无
参数:phead:链表的头指针 new:插入的新节点指针
****************************************/
void insert_head(struct node *head,struct node *new)
{

    new->pNEXT =  head->pNEXT;

    head->pNEXT = new;

    head->datas += 1;

}

/****************************************
函数名:ergodic
作用:遍历链表的各个节点
返回值:无
参数:ph:链表的头指针
****************************************/
void ergodic(struct node *ph)
{


        struct node *p = ph;        //创建临时指针变量
        int cat = 0;                //临时计数

        printf("datas number is a: %d\n",p->datas);    //输出打印链表节点个数

        while(NULL !=  p->pNEXT)                       //判断pnext是否指向NULL 
            {
                cat++;                                 //循环一次计数加一
                printf("datas number is :%d\n",cat);   //输出当前是第几个节点
                printf("datas is: %d\n",p->pNEXT->datas);  //输出当前节点数据区数据   
                p = p->pNEXT;                              //临时指针变量指向下一个节点




            }

        


}



int main(void)
{
    struct node *phead = create(0);

    insert_tail(phead,create(1));
    insert_tail(phead,create(2));
    insert_tail(phead,create(3));





        ergodic(phead);        

       

      return 0;


}

运行结果:

相关推荐
就爱学编程3 分钟前
重生之我在异世界学编程之C语言小项目:通讯录
c语言·开发语言·数据结构·算法
学术头条8 分钟前
清华、智谱团队:探索 RLHF 的 scaling laws
人工智能·深度学习·算法·机器学习·语言模型·计算语言学
Oneforlove_twoforjob26 分钟前
【Java基础面试题025】什么是Java的Integer缓存池?
java·开发语言·缓存
emoji11111127 分钟前
前端对页面数据进行缓存
开发语言·前端·javascript
每天都要学信号38 分钟前
Python(第一天)
开发语言·python
TENET信条38 分钟前
day53 第十一章:图论part04
开发语言·c#·图论
Schwertlilien40 分钟前
图像处理-Ch4-频率域处理
算法
北国无红豆43 分钟前
【CAN总线】STM32的CAN外设
c语言·stm32·嵌入式硬件
生信圆桌1 小时前
【生信圆桌x教程系列】如何安装 seurat V5版本R包,最详细安装手册
开发语言·r语言
IT猿手1 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解TP1-TP10及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·深度学习·算法·机器学习·matlab·多目标算法