C 单向链表的创建、插入及删除
链表是一种常见的基础数据结构,结构体指针在这里得到了充分的利用。链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随意增添,删除,插入节点。链表都有一个头指针,一般以head来表示,存放的是一个地址。链表中的节点分为两类,头结点和一般节点,头结点是没有数据域的。链表中每个节点都分为两部分,一个数据域,一个是指针域。说到这里你应该就明白了,链表就如同车链子一样,head指向第一个元素:第一个元素又指向第二个元素;……,直到最后一个元素,该元素不再指向其它元素,它称为“表尾”,它的地址部分放一个“NULL”(表示“空地址”),链表到此结束。
#include <stdio.h>//printf()
#include <stdlib.h>//malloc(), free(), system()
#include <string.h>//memset()内存初始化
typedef struct Node *PtrToNode;
struct Node
{
int myData;
PtrToNode nextPtr;
};
注意相应头文件的包含!!!
1、单节点链表的创建
PtrToNode phead = (PtrToNode)malloc(sizeof(struct Node));//申请第一个节点内存空间,phead指向该内存空间
if (phead == NULL)
{
printf("malloc fair\n");
system("pause");
}
memset(phead, 0, sizeof(struct Node));//内存空间清零
phead->myData = 100;
phead->nextPtr = NULL;
2、连续链表的创建
创建连续链表时,主要思想是:每创建一个新节点,就可以为其内部除指针外的其他数据赋值,指针数据暂时不管。当下一个结点创建完毕后,再将之前未赋值的指针指向该结点。
连续列表的创建过程中,需要用到三个指针,分别指向:头节点地址、中间结点地址和尾节点地址,并注意及时更新。
PtrToNode Creat(int num)
{
PtrToNode phead = (PtrToNode)malloc(sizeof(struct Node));//头结点地址
if (phead == NULL)
{
printf("malloc fair\n");
system("pause");
}
PtrToNode p0 = phead;//中间结点地址
PtrToNode p1 = phead;//尾结点地址
memset(phead, 0, sizeof(struct Node));//内存空间清零
phead->myData = 0;
int i = 0;
for (i = 1; i < num; i++)
{
p0 = (PtrToNode)malloc(sizeof(struct Node));
if (p0 == NULL)
{
printf("malloc fair\n");
system("pause");
}
memset(p0, 0, sizeof(struct Node));//内存空间清零
p0->myData = i;//中间结点创建完毕
p1->nextPtr = p0;//将之前尾结点的nextPtr指向新创建的结点地址
p1= p0;//更新尾节点
}
p1->nextPtr = NULL;//将链表尾结点的nextPtr赋值为NULL
return phead;
}
3、指定位置节点的插入
phead为链表首结点地址,num指定插入的位置(本程序链表结点序号从0开始),data是插入节点的数据信息。
PtrToNode Insert(PtrToNode phead, int num, int data)
{
PtrToNode p = phead;
int i = 0;
for(i = 0; i < num - 1; i++)//p指向第num -1个结点的首地址(首结点为第0个结点)
p = p->nextPtr;
PtrToNode pnew = (PtrToNode)malloc(sizeof(struct Node));
PtrToNode pmid = p->nextPtr;//暂时存放p->nextPtr
p->nextPtr = pnew;
pnew->myData = data;
pnew->nextPtr = pmid;
return phead;
}
4、指定位置结点的删除
phead为链表首结点地址,num指定删除的位置(本程序链表结点序号从0开始)。
PtrToNode Delete(PtrToNode phead, int num)
{
PtrToNode p = phead;
int i = 0;
for (i = 0; i < num-1 ; i++)//p指向第num-1个结点的首地址(首结点为第0个结点)
p = p->nextPtr;
PtrToNode pnum = p->nextPtr;
p->nextPtr = pnum->nextPtr;
free(pnum);//注意将删除的结点内存空间释放
return phead;
}
C 单向链表的创建、插入及删除的更多相关文章
- C语言习题 链表建立,插入,删除,输出
Problem B: C语言习题 链表建立,插入,删除,输出 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 222 Solved: 92 [Subm ...
- YTU 2430: C语言习题 链表建立,插入,删除,输出
2430: C语言习题 链表建立,插入,删除,输出 时间限制: 1 Sec 内存限制: 128 MB 提交: 576 解决: 280 题目描述 编写一个函数creatlink,用来建立一个动态链表 ...
- C语言实现简单的单向链表(创建、插入、删除)及等效STL实现代码
实现个算法,懒得手写链表,于是用C++的forward_list,没有next()方法感觉很不好使,比如一个对单向链表的最简单功能要求: input: 1 2 5 3 4 output: 1-> ...
- 笔试算法题(19):判断两条单向链表的公共节点 & 字符集删除函数
出题:给定两个单向链表的头结点,判断其是否有公共节点并确定第一个公共节点的索引: 分析: 由于是单向链表,所以每个节点有且仅有一个后续节点,所以只可能是Y型交叉(每条链表中的某个节点同时指向一个公共节 ...
- C语言:创建动态单向链表,创建完成后,输出每一个节点的数据信息。
// // main.c // dynamic_link_list // // Created by ma c on 15/8/5. // Copyright (c) 2015. All ri ...
- C语言双链表遍历,插入,删除
#include<stdio.h> #include<stdlib.h> #include <string.h> #define bzero(a, b) memse ...
- C语言链表总结(创建,排序,增加,删除)
#include <stdio.h>#include <stdlib.h> typedef struct NODE{ int data ; struct NODE * pNex ...
- 单向链表在O(1)时间内删除一个节点
说删链表节点,第一时间想到就是遍历整个链表,找到删除节点的前驱,改变节点指向,删除节点,但是,这样删除单链表的某一节点,时间复杂度就是O(n),不符合要求: 时间复杂度是O(n)的做法就不说了,看看O ...
- DS-4-单链表的各种插入与删除的实现
typedef struct LNode { int data; struct LNode *next; }LNode, *LinkList; 带头结点的按位序插入: //在第i个位置插入元素e bo ...
随机推荐
- svg绘制一个简单地饼图
一个简单地svg绘制饼图的demo,代码如下 <!DOCTYPE html> <html> <head> <meta charset="UTF-8& ...
- php JS 导出表格特殊处理
但是这样导出身份证号会变为科学计数: 解决方法就是: 我们了解一下excel从web页面上导出的原理.当我们把这些数据发送到客户端时,我们想让客户端程序(浏览器)以excel的格式读取 它,所以把mi ...
- dotnet 在build restore publish 的时候不显示警告
dotnet restore -nowarn:msb3202,nu1503,cs1591 dotnet build -nowarn:msb3202,nu1503,cs1591 --no-restore ...
- xml代码修改图片颜色
<?xml version="1.0" encoding="utf-8"?> <bitmap xmlns:android="http ...
- python搭建服务器时nginx的有关问题
最近在学习Python服务器搭建的内容,网上大多是Windows环境下的,由于我使用的是Mac,为了不想装双系统折腾,就只好一步步采坑了.比较基础的我一步步记录下来, 1.安装nginx: brew ...
- ContentType与SpiringMvc
转载https://blog.csdn.net/mingtianhaiyouwo/article/details/51459764
- NOIP考点
NOIP考点 基础算法 图 树 数论 数据结构 动态规划 搜索 其他算法 省选知识点汇总 图论 数据结构 字符串相关算法及数据结构 数学 计算几何 搜索 动态规划 其他算法 转自:巨佬的博客 加*号是 ...
- s6-6 TCP 连接释放
TCP 连接释放 任何一方在没有数据要传送的时候,都可以发送一个FIN置位了的 TCP 数据段 当FIN被确认的时候,该方向的连接被关闭 当双向连接都关闭了的时候,连接释放 两军队问题 两军队问题 ( ...
- java环境下载
https://repo.huaweicloud.com/java/jdk/8u201-b09/
- windows安装zookeeper
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应用提供一致性服务的软件,提供的功 ...