本文实例讲述了C语言实现带头结点的链表的创建、查找、插入、删除操作。是数据结构中链表部分的基础操作。分享给大家供大家参考。具体方法如下:
#include <stdio.h> #include <stdlib.h> typedef struct node { int data; struct node* next;// 这个地方注意结构体变量的定义规则 } Node, *PNode; Node* createLinklist(int length) { int i = 0; PNode pHeader = NULL; PNode pTail = NULL; PNode pTemp = NULL; printf("create\n"); pHeader = (PNode)malloc(sizeof(Node));// 申请头结点 if (!pHeader) { exit(-1); } pHeader->next = NULL; for (i = 0; i < length; i++) { pTemp = (PNode)malloc(sizeof(Node));// 用malloc要包含头文件 if (!pTemp) { exit(-1); } pTemp->data = i*10; pTemp->next = NULL; if (!pHeader->next) { // 第一个结点是空的,则先连接第一个结点 pHeader->next = pTemp; } else { pTail->next = pTemp; } pTail = pTemp; } return pHeader; } Node* search(PNode pHeader, int k) { PNode p = pHeader->next; int i = 1; printf("search\n"); while(p && (i < k)) { p = p->next; i++; } if (p && (i == k)) // 这步的i == k是必须的, // 因为如果一开始的时候 i就 >= k并且pHeader->next还不为NULL这一步就会必过,导致返回的是第一个元素的值 { return p; } return NULL; } int insert(PNode pHeader, PNode pNew, int k) { PNode p = NULL; printf("insert\n"); if ( 1 == k ) { p = pHeader; } else { printf("==>"); p = search(pHeader, k-1); } if (p) { // 带头结点和不带头结点的主要区别之一就在这 // 如果不带头结点,那么在第一个位置插入结点的操作应该是 // pNew->next = p; // p = pNew; // 带头结点的操作如下 pNew->next = p->next; p->next = pNew; return 1; } return 0; } int deleteNode(PNode pHeader, int k) { PNode p = NULL; printf("deleteNode\n"); if (1 == k) { p = pHeader->next; } else { printf("==>"); p = search(pHeader, k-1); } if (p && p->next) { // 不带头结点的操作时删除第一个结点的操作 // Node* temp = p; // p = p->next; // free(temp); // 带头结点的操作如下 PNode temp = p->next; p->next = temp->next; free(temp); return 1; } else { printf("Not Found\n"); return 0; } } void print(PNode pHeader) { PNode p = pHeader->next; printf("print\n "); while(p) { printf("%4d ", p->data); p = p->next; } putchar('\n'); } void freeList(PNode pH) { PNode p = NULL; printf("freeList\n"); while(NULL != pH) { p = pH; pH = pH->next; printf("%4d be freed\n", p->data); free(p); } } int main(void) { PNode pHeader = NULL;// C和C++中判断指针为空都是用NULL宏(全大写) PNode pNew = NULL; PNode result = NULL; pHeader = createLinklist(10); print(pHeader); result = search(pHeader, 5); if ( result ) { printf("%d\n", result->data); } else { printf("Not Found\n"); } pNew = (PNode)malloc(sizeof(Node)); if (!pNew) { exit(-1); } pNew->data = 100; pNew->next = NULL; insert(pHeader, pNew, 5); print(pHeader); deleteNode(pHeader, 12); print(pHeader); freeList(pHeader); return 0; }
上述实例备有较为详尽的注释,相信不难理解。希望本文所述对大家C程序数据结构与算法设计有所帮助。
我或多或少只是在学习C语言,我被分配了一个简单的任务,处理双链表、动态数据分配和递归。我创建了一个只有10个整数的数组,我试图使用递归将这些整数放入一个排序的双链表中。我在向链表中插入节点时遇到了一些问题;我想我已经搞定了第一个节点,但我不确定其他节点是否有意义。现在我也遇到了一个分割错误。。。谢谢你的帮助!
本文向大家介绍C语言创建和操作单链表数据结构的实例教程,包括了C语言创建和操作单链表数据结构的实例教程的使用技巧和注意事项,需要的朋友参考一下 1,为什么要用到链表 数组作为存放同类数据的集合,给我们在程序设计时带来很多的方便,增加了灵活性。但数组也同样存在一些弊病。如数组的大小在定义时要事先规定,不能在程序中进行调整,这样一来,在程序设计中针对不同问题有时需要3 0个大小的数组,有时需要5 0个
这是我的代码,在删除的时候总是删不掉尾节点,该如何处理呢?
本文向大家介绍C语言单链表的实现,包括了C语言单链表的实现的使用技巧和注意事项,需要的朋友参考一下 单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素。 链表结构: SList.h SList.cpp Test.cpp 以上内容是小编给大家介绍的C语言单链表的实现代码,希望对大家有所帮助!
本文向大家介绍C++实现顺序表的常用操作(插入删出查找输出),包括了C++实现顺序表的常用操作(插入删出查找输出)的使用技巧和注意事项,需要的朋友参考一下 实现顺序表的插入,删除,查找,输出操作在C语言中经常用到。下面小编给大家整理实现代码,一起看下吧 代码如下所示: 【Test_Sequence.cpp】 效果如下: 以上所述是小编给大家介绍的C++实现顺序表的常用操作(插入删出查找输出),希望
本文向大家介绍C语言实现数据结构和双向链表操作,包括了C语言实现数据结构和双向链表操作的使用技巧和注意事项,需要的朋友参考一下 数据结构 双向链表的实现 双向链表中的每一个结点都含有两个指针域,一个指针域存放其后继结点的存储地址,另一个指针域则存放其前驱结点的存储地址。 双向链表结点的类型描述: 其中,prior域存放的是其前驱结点的存储地址,next域存放的是其后继结点的存储地址。 双