🥳每日一练-拆分链表-JS简易版

今天分享的内容非常简单,是拆分一个链表,将链表中次序为奇数的节点放到链表 A 中,次序为偶数的节点放到链表 B 中

我们开始吧

准备数据

javascript 复制代码
const data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];

class Node {
	constructor(value) {
		this.value = value;
		this.next = null;
	}
}

const generator = (array) => {
	let root = { next: null },
		node = root;
	array.forEach((item) => {
		const temp = new Node(item);
		node.next = temp;
		node = temp;
	});

	return root.next;
};

const linkList = generator(data);

上面代码准备了一个含有十个节点的单链表,1 节点作为链表的头节点。

下面将会拆分这个链表,将奇数节点放在链表 A中,偶数次序的节点放在链表 B 中

javascript 复制代码
const splitLinkList = (linkList) => {
	const listA = linkList,
		listB = linkList.next;
	let node = listB.next,
		ra = listA,
		rb = listB;
	let i = 2;

	while (node) {
		if (i % 2 == 0) {
			ra.next = node;
			ra = ra.next;
		} else if (i % 2 == 1) {
			rb.next = node;
			rb = rb.next;
		}
		node = node.next;
		i++;
	}
	ra.next = null;
	rb.next = null;
	return { listA, listB };
};

定义了一个函数splitLinkList,接受一个链表作为参数,并且将两个链表作为返回值。返回的两个链表也是没有空节点作为头节点

代码的开头将 listA 指向linkList的第一个节点,将listB指向linkList的第二个节点,并且用新变量 node指向linkList第三个节点,然后 i 也是从 2 开始,待会遍历linkList也是从第三个节点开始。

另外声明了两个变量 ra,rb,分别表示listAlistB的尾节点。

while中开始遍历,如果 i 是奇数,就将新节点插入listB中;如果 i 是偶数,就将新节点插入listA中。直到linkList遍历完成

在函数的最后需要将 rarb 的 next 置为 null。对尾节点做专门处理,放置两个链表的尾节点连在一起

最后返回两个新链表

测试代码

javascript 复制代码
const { listA, listB } = splitLinkList(linkList);

const printLinkList = (linkList) => {
	while (linkList) {
		console.log(linkList.value);
		linkList = linkList.next;
	}
};

printLinkList(listA);
// 1
// 3
// 5
// 7
// 9
printLinkList(listB);
// 2
// 4
// 6
// 8
// 10

用了一个函数来顺序输出链表,方便我们观察链表中有哪些数据。

从输出结构中看到,listA 中只有奇数节点,listB 中只有偶数节点。符合预期,代码测试成功

总结

这篇文章分享了链表的拆分,问题很简单,不难。属于指针操作的基本功。在之后的二叉树,图等操作都离不开指针的操作,基础很重要

你觉得这篇文章怎么样?我每天都会分享一篇算法小练习,喜欢就点赞+关注吧

相关推荐
苯酸氨酰糖化物2 分钟前
基于深度学习(U-Net架构下改良GAN与ViT算法)的高效肺部多模态疾病预测模型
人工智能·深度学习·算法·生成对抗网络·视觉检测
jinyishu_3 分钟前
链表经典算法题(2)
c语言·数据结构·链表
y = xⁿ5 分钟前
MySQL为什么抛弃了B树,选择B+树?(含面试回答)
数据结构·b树·面试
feng_you_ying_li5 分钟前
异常,try catch ,throw的介绍与运用
算法
SuperEugene7 分钟前
Vue3 配置驱动表格:列配置/操作配置/分页配置,统一表格渲染|配置驱动开发实战篇
前端·javascript·vue.js·驱动开发·架构
weixin_471383038 分钟前
[特殊字符] React Flow 从入门到理解
开发语言·前端·javascript
其实防守也摸鱼9 分钟前
ctfshow--VIP题目限免(包含原理和知识拓展)前10个
网络·算法·安全·学习笔记·ctf·泄露·web类型
自我意识的多元宇宙10 分钟前
二叉树遍历方式代码解读(1递归)
java·数据结构·算法
逻辑驱动的ken19 分钟前
Java高频面试考点04
java·开发语言·算法·哈希算法·散列表
_日拱一卒20 分钟前
LeetCode:142环形链表Ⅱ
算法·leetcode·链表