c语言如何查询结构体中的数据(数据结构的链表怎么连接c语言)

技术如何进行数据结构C语言链表的实现这篇文章将为大家详细讲解有关如何进行数据结构C语言链表的实现,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言需要用到的函数库#inc

本文将详细说明如何用C语言实现数据结构链表。这篇文章的内容质量很高,所以边肖会分享给大家作为参考。希望你看完这篇文章后有所了解。

前言

需要用到的函数库

# includestdio.h

# includedmalloc.h malloc函数用于动态分配空间,相当于Java中new的角色。

先是需要创建一个节点的结构体

typedefstruct{

intdata

structlinkNode *下一步;

} linkNode00-1010

函数

votinilinklist(link node * FP){//初始化链表,传入头节点。

linkNode * point=fp//定义指向头节点的指针

for(inti=0;i5;I){ 0

linkNode * node=malloc(sizeof(linkNode));

节点数据=I;

节点-下一个=空;

点-下一个=节点;

点=点-下一个;

}

}

1. 链表初始化

intcountlistlength(link node * FP){//FP :链表头节点

linkNode * point=fp//定义指向头节点的指针

int sum=0;//用于计算链表节点数。

while(点-下一个){ 0

总和;

点=点-下一个;

}

returnsum

}

2. 计算链表长度

voitprintlinklist(link node * FP){//传入链表头节点

linkNode * point=fp//定义指向头节点的指针

Printf('链表内容如下:\ n ');

while(点-下一个){ 0

link node * node=point-next;

printf('%d\t ',节点数据);

点=点-下一个;

}

printf(' \ n ');

}

3. 打印链表

int

 countListLength(linkNode *fp){//fp:链表头节点
    linkNode *point = fp;//定义指针指向头节点
    int sum = 0;         //用来计算链表节点个数
    while(point->next){
        sum++;
        point=point->next;
    }
    return sum;
}

5. 删除链表中指定位置节点

int deleteNode(int index,linkNode *fp){//index:链表中节点的下标,fp:链表头节点
    linkNode *point = fp;//定义指针指向头节点
    if(index<0||index>(countListLength(fp)-1)){//判断index是否有效(在链表长度范围内)
        printf("下标不在链表内!");
        return 1;                           //返回1表示删除失败
    }else{
        for(int i=0;i<index;i++){           //遍历找到下标前一个位置
            point=point->next;
        }
        linkNode *node = point->next;       
        point->next=node->next;             //删除下标位置节点
        return 0;                           //返回0表示删除成功
    }
}

6. 向链表中指定位置插入节点

void insertLinkNode(linkNode *fp,int index,int data){//index:链表中节点的下标,fp:链表头节点,data:插入的新数据
    linkNode *point = fp;//定义指针指向头节点
    if(index<0||index>(countListLength(fp)-1)){//判断index是否有效(在链表长度范围内)
        printf("下标不在链表内!");              
        return;
    }else{
        for (int i=0;i<index;i++)
        point=point->next;                  //找到下标位置前一个节点
        
        linkNode *node = malloc(sizeof(linkNode));
        node->data=data;                    //创建新节点
        node->next=point->next;             //将下标前一个节点的next赋值给node的next
        point->next = node;                 //将新创建的节点的地址给下标位置前一个节点
    }
}

7. 全代码+运行效果

#include<stdio.h>
#include<malloc.h>
typedef struct{
    int data;
    struct linkNode* next;
}linkNode;
//初始化链表
void iniLinkList(linkNode *fp){//初始化链表传入一个头节点
    linkNode *point = fp;//定义一个指针指向头节点
    for(int i=0;i<5;i++){
        linkNode *node = malloc(sizeof(linkNode));
        node->data=i;
        node->next=NULL;
        point->next = node;
        point=point->next;
    }
}
//向链表中指定位置插入节点
void insertLinkNode(linkNode *fp,int index,int data){//index:链表中节点的下标,fp:链表头节点,data:插入的新数据
    linkNode *point = fp;//定义指针指向头节点
    if(index<0||index>(countListLength(fp)-1)){//判断index是否有效(在链表长度范围内)
        printf("下标不在链表内!");              
        return;
    }else{
        for (int i=0;i<index;i++)
        point=point->next;                  //找到下标位置前一个节点
        
        linkNode *node = malloc(sizeof(linkNode));
        node->data=data;                    //创建新节点
        node->next=point->next;             //将下标前一个节点的next赋值给node的next
        point->next = node;                 //将新创建的节点的地址给下标位置前一个节点
    }
}
//删除链表中指定位置节点
int deleteNode(int index,linkNode *fp){//index:链表中节点的下标,fp:链表头节点
    linkNode *point = fp;//定义指针指向头节点
    if(index<0||index>(countListLength(fp)-1)){//判断index是否有效(在链表长度范围内)
        printf("下标不在链表内!");
        return 1;                           //返回1表示删除失败
    }else{
        for(int i=0;i<index;i++){           //遍历找到下标前一个位置
            point=point->next;
        }
        linkNode *node = point->next;       
        point->next=node->next;             //删除下标位置节点
        return 0;                           //返回0表示删除成功
    }
}
//计算链表长度
int countListLength(linkNode *fp){//fp:链表头节点
    linkNode *point = fp;//定义指针指向头节点
    int sum = 0;         //用来计算链表节点个数
    while(point->next){
        sum++;
        point=point->next;
    }
    return sum;
}
//打印链表
void printLinkList(linkNode *fp){//传入链表头节点
    linkNode *point = fp;//定义指针指向头节点
    printf("链表内容如下:\n");
    while(point->next){
        linkNode *node = point->next;
        printf("%d\t",node->data);
        point=point->next;
    }
    printf("\n");
}
int main(){
    linkNode *linkList = malloc(sizeof(linkNode));//创建一个头节点
    iniLinkList(linkList);
    printLinkList(linkList);
    deleteNode(3,linkList);
    printf("删除后");
    printLinkList(linkList);
    insertLinkNode(linkList,3,7);
    printf("插入后");
    printLinkList(linkList);
    return 0;
}
//	链表内容如下:
//	0       1       2       3       4
//	删除后链表内容如下:
//	0       1       2       4
//	插入后链表内容如下:
//	0       1       2       7       4

关于如何进行数据结构C语言链表的实现就分享到这里了,希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/151264.html

(0)

相关推荐

  • zabbix4.0-编译安装:LNAP+zabbix4.0

    技术zabbix4.0-编译安装:LNAP+zabbix4.0 zabbix4.0-编译安装:LNAP+zabbix4.0相关网址:
    nginx下载地址:http://nginx.org/en/down

    礼包 2021年10月27日
  • 有理数100道带答案过程,求100道有理数混合计算,七上)

    技术有理数100道带答案过程,求100道有理数混合计算,七上)-2/9-7/9-56 4。6-(-3/4 1。6-4-3/4) 1/2 3 5/6-7/12 [2/3-4-1/4 (-0。4)]/1/3 2 22 (-4

    生活 2021年10月23日
  • 分析HTML开发工具中的HBuilder

    技术分析HTML开发工具中的HBuilder本篇内容主要讲解“分析HTML开发工具中的HBuilder”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“分析HTML开发工具中的H

    攻略 2021年11月5日
  • 奥运会会歌,历届奥运会的会歌是什么

    技术奥运会会歌,历届奥运会的会歌是什么·2008北京奥运应征歌曲《梦想在望》1984洛杉矶奥运会主题曲
    歌名奥运会会歌:ReachOut欢乐通宵
    词曲:[美]约翰·威廉姆斯(JohnWilliams)
    演唱:[美]莱昂纳

    生活 2021年10月31日
  • mysql中动态语句编写的引号怎么用

    技术mysql中动态语句编写的引号怎么用这篇文章主要为大家展示了“mysql中动态语句编写的引号怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql中动态语句编写的

    攻略 2021年11月2日
  • SQL注入和SQL注入工具的基础知识是什么

    技术SQL注入和SQL注入工具的基础知识是什么这期内容当中小编将会给大家带来有关SQL注入和SQL注入工具的基础知识是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。黑客数据库的主要

    攻略 2021年12月1日