《算法通关指南:数据结构和算法篇 --- 链表相关算法题》--- 1. 队列安排,2.约瑟夫问题

🔥小龙报:个人主页

🎬作者简介:C++研发,嵌入式,机器人方向学习者

❄️个人专栏:《C语言》 《算法通关指南 》
永远相信美好的事情即将发生

文章目录


前言

本专栏聚焦算法题实战,系统讲解算法模块:以《c++编程》,《数据结构和算法》《基础算法》《算法实战》 等几个板块以题带点,讲解思路与代码实现,帮助大家快速提升代码能力ps:本章节题目分两部分,比较基础笔者只附上代码供大家参考,其他的笔者会附上自己的思考和讲解,希望和大家一起努力见证自己的算法成长

一、队列安排

1.1题目

链接:队列安排

1.2算法原理

频繁的在某一个位置之前和之后插入元素,因此可以用双向循环的链表来模拟。

1.3代码

c 复制代码
#include <iostream>
using namespace std;
const int N = 1e5 + 10;
int pre[N];
int ne[N];
int mp[N]; // mp[i] 表⽰ i 这个同学是否已经出队

int main()
{
	int n;
	cin >> n;

	ne[0] = 1;
	mp[1] = 1;
	for (int i = 2; i <= n; i++)
	{
		int k, p;
		cin >> k >> p;

		if (p == 0)
		{
			pre[i] = pre[k];
			ne[i] = k;

			ne[pre[k]] = i;
			pre[k] = i;
			mp[i] = 1;
		}
		else if (p == 1)
		{
			pre[i] = k;
			ne[i] = ne[k];

			pre[ne[k]] = i;
			ne[k] = i;
			mp[i] = 1;
		}
	}


	int m;
	cin >> m;

	for (int i = 1; i <= m; i++)
	{
		int x;
		cin >> x;

		if (mp[x] == 0)  // 如果 x 已经被删除,忽视这条指令 
			continue;

		ne[pre[x]] = ne[x];
		pre[ne[x]] = pre[x];
		mp[x] = 0;
	}

	for (int i = ne[0]; i; i = ne[i])
		cout << i << " ";
	return 0;
}

二、约瑟夫问题

2.1题目

链接:约瑟夫问题

2.2算法原理

使用循环链表模拟即可。

2.3代码

c 复制代码
#include <iostream>
using namespace std;
const int N = 110;
int ne[N];

int main()
{
	int n, m;
	cin >> n >> m;

	// 创建循环链表
	for (int i = 1; i < n; i++)
		ne[i] = i + 1;
	ne[n] = 1;

	// 模拟约瑟夫游戏的过程 
	int t = n;
	for (int i = 1; i <= n; i++)  // 执行n次出圈操作
	{
		for (int i = 1; i < m; i++)  // 让 t 向后移动 m - 1 次
			t = ne[t];

		cout << ne[t] << " ";
		ne[t] = ne[ne[t]];
	}
	return 0;
}

总结与每日励志

摘要: 本文分享了两个链表相关的算法实战题目:《队列安排》和《约瑟夫问题》。 队列安排:通过双向循环链表模拟学生插入和删除操作,使用pre和ne数组维护前驱与后继关系,高效处理动态调整。 约瑟夫问题:利用循环链表模拟游戏过程,每次移动m-1次后删除节点,直至所有节点出圈。 代码简洁高效,适合算法初学者练习链表操作。文末附励志语句,鼓励坚持学习。 关键词:双向链表、循环链表、算法实战、动态模拟

相关推荐
Zevalin爱灰灰25 分钟前
现代密码学 第二章——流密码【下】
算法·密码学
飞Link2 小时前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
郝学胜-神的一滴3 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish4 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午4 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
Brilliantwxx4 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
叼烟扛炮5 小时前
C++第三讲:类和对象(中)
开发语言·c++·类和对象
KuaCpp5 小时前
C++新特性学习
c++·学习
墨染千千秋5 小时前
C/C++ Keywords
c语言·c++
ximu_polaris5 小时前
设计模式(C++)-行为型模式-中介者模式
c++·设计模式·中介者模式