链表任意位置插入删除

链表的插入删除主要是要考虑如果为空表,删除第一个等特殊情况,考虑全面。

具体实现如下

c 复制代码
#include<stdlib.h>
#include<stdio.h>
struct Node {
	int data;
	struct Node* next;
};
struct Node* head;
void print()
{
	struct Node* temp = head;
	printf("list is:");
	while (temp != NULL)//遍历操作
	{
		printf(" %d", temp->data);
		temp = temp->next;

	}
	printf("\n");
}
void Insert(int data, int n)
{
	//先创建该结点
	struct Node* temp1 = (struct Node*)malloc(sizeof(struct Node));
	temp1->data = data;
	temp1->next = NULL;
	if (n == 1)//如果插在第一个位置
	{
		temp1->next = head;//空表也可以
		head = temp1;
		return;
	}
	//找到要插入位置的前一个
	struct Node* temp2 = head;
	for (int i = 0; i < n - 2; i++)//移动n-2次
	{
		temp2 = temp2->next;
	}
	//把temp2的位置移到第n-1个位置
	temp1->next = temp2->next;
	temp2->next = temp1;
	return;
}
//delete node
//注意如果想删除的结点位于头结点
//删除后要释放空间
void Delete(int n)//删除第n个位置
{
		struct Node* temp1 = head;
		// if the previous node does not exist
		if (n == 1)
		{
			head = head->next;
			free(temp1);
			return;
		}
		// if the previous node  exists
		for (int i = 0; i < n - 2; i++)//移动n-2次
		{
			temp1 = temp1->next;//temp1 points to(n-1)th Node
		}
		struct Node* temp2 = temp1->next;//准备删除的结点
			temp1->next = temp2->next;
		free(temp2);
}
int main()
{
	head = NULL;//初始化空表
	Insert(2, 1);
	Insert(3, 1);
	Insert(4, 3);
	print();//list is: 3 2 4

	Delete(1);
	print();//list is: 2 4
	Delete(2);
	print();//list is: 2 
	return 0;
}
相关推荐
夏鹏今天学习了吗1 小时前
【LeetCode热题100(31/100)】K 个一组翻转链表
算法·leetcode·链表
Pluchon2 小时前
硅基计划4.0 算法 字符串
java·数据结构·学习·算法
麦格芬2302 小时前
LeetCode 416 分割等和子集
数据结构·算法
2401_841495646 小时前
【数据结构】顺序表的基本操作
数据结构·c++·算法·顺序表·线性表·线性结构·顺序表的基本操作
自信的小螺丝钉7 小时前
Leetcode 138. 随机链表的复制 哈希 / 拼接+拆分
leetcode·链表·哈希算法
未知陨落7 小时前
LeetCode:70.最小栈
数据结构·算法·leetcode
小糖学代码7 小时前
STL的list模拟实现(带移动构造和emplace版本)
c语言·数据结构·c++·windows·list
shenghaide_jiahu7 小时前
leetcode430:扁平化多级双向链表
数据结构·链表
失散137 小时前
软件设计师——03 数据结构(上)
数据结构·软考·软件设计师
Chance_to_win7 小时前
数据结构之双向链表
数据结构·链表