链表oj测试题(上)

链表的申明:

cpp 复制代码
struct ListNode
{
	int val;
	struct ListNode* next;
};

1.题1

删除指定元素 例如:链表1 2 6 3 4 5 6,然后选择删除元素6,返回的链表为1 2 3 4 5 。

代码演示:

cpp 复制代码
typedef struct ListNode ListNode;
 ListNode* removeElements(ListNode* head, int val)
{
	 ListNode* newHead, * newTail;
	 newHead = newTail = NULL;
	 ListNode* pcur = head;
	 while (pcur)
	 {
		 if (pcur->val != val)//不是val就插入新链表
		 {
			 if (newHead == NULL)
			 {
				 newHead = newTail = pcur;//空链表就将头节点和尾节点都指向pcur
			 }
			 else//链表不为空
			 {
				 newTail->next = pcur;
				 newTail = newTail->next;
			 }
          
		 }
		 pcur = pcur->next;

	 }
	 if (newTail)//判断最后的尾节点是否为NULL,如果为NULL的话就为对其去指针域就会报错
	 {
		 newTail->next = NULL;
	 }
	 return newHead;
}

在这里的思路就是遍历原链表碰到不为val的数就尾插到新创建的链表,最后将新链表的头返回来,大家也可以试试将它们的上一个节点的地址保存val下一个节点的地址,然后再将val的空间释放掉,这个方法虽然有些麻烦,但是大家可以练习一下思维。

在这里我们我们要用到尾插的代码,和创建节点才能创建好链表,虽然可以不包装成函数,但是如果将其包装成函数的话可以减少下次需要使用到它的时候,减轻代码量。

尾插:

cpp 复制代码
void InsertBack(ListNode**phead,int val)
{
 assert(phead);
 ListNode* newNode = GetNode(val);
 if (*phead == NULL)
 {
	 *phead = newNode;
	 return;
 }

 ListNode* ptail = *phead;
 while (ptail->next)
 {
	 ptail = ptail->next;
 }
 ptail ->next= newNode;
}

创建节点:

cpp 复制代码
ListNode* GetNode(int val)
{
 ListNode* newNode = (ListNode*)malloc(sizeof(ListNode));
 assert(newNode);
 newNode->val = val;
 newNode->next = NULL;
 return newNode;
}

我们可以测试一下代码是否可以达到预想效果:

2.题2

中间节点,如果有两个中间节点,返回第二个。

代码演示:

cpp 复制代码
ListNode* middleNode(ListNode* phead)
{
 ListNode* slow, * fast;
 slow = fast = phead;
 while (fast && fast->next)//当fast或者fast->next其中一个为空就跳出循环,此时slow刚好指向中节点。
 {//判断式的顺序不能替换,因为当fast为空时,结果fast->在前面这就导致了对空指针的引用,会报错。
	 slow = slow->next;//每次走一步
	 fast = fast->next->next;//每次走两步
 }
 return slow;
}

我们在这里用到的是快慢指针法,这个方法就是创建两个指针变量,然后快指针一次走两步,慢指针一次走一步,当快指针为NULL,或者慢指针next为NULL,循环停止,慢指针的位置就是中间节点的位置·。

我们来测试一下:

大家一起加油!
谢谢

相关推荐
算法鑫探3 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
木子墨5163 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
2501_921960854 小时前
双相自指图与弦论边界非对易性的结构同源
数据结构
Liangwei Lin4 小时前
洛谷 P3133 [USACO16JAN] Radio Contact G
数据结构·算法
锅挤7 小时前
数据结构复习(第五章):树与二叉树
数据结构
杨凯凡8 小时前
【014】基本类型与包装类:缓存、相等性、NPE
java·数据结构·缓存
故事和你918 小时前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
想唱rap8 小时前
C++智能指针
linux·jvm·数据结构·c++·mysql·ubuntu·bash
会编程的土豆9 小时前
【日常做题】 代码随想录(岛屿最大面积+寻宝)
数据结构·算法·图论
疯狂打码的少年10 小时前
有序线性表删除一个元素:顺序存储 vs 单链表,平均要移动多少个元素?
数据结构·算法·链表