C (1094) : DS双向链表—前驱后继

Description

在双向链表中,A有一个指针指向了后继节点B,同时,B又有一个指向前驱节点A的指针。这样不仅能从链表头节点的位置遍历整个链表所有节点,也能从链表尾节点开始遍历所有节点。

对于给定的一列数据,按照给定的顺序建立双向链表,按照关键字找到相应节点,输出此节点的前驱节点关键字及后继节点关键字。

Input

第一行两个正整数n(代表节点个数),m(代表要找的关键字的个数)。

接下来输入n个整数为关键字key(数据保证关键字在数列中没有重复)。

接下来有m个要查找的关键字,每个占一行。

Output

对给定的每个关键字,输出此关键字前驱节点关键字和后继节点关键字。如果给定的关键字没有前驱或者后继,则不输出。给定关键字为每个输出占一行。

Sample

AC代码:

cpp 复制代码
#include <iostream>
using namespace std;
typedef struct DNode{
	int data;
	struct DNode* pr, * next;
}DNode,*DLinkList;

void InitList(DLinkList& L){
	L = (DNode*)malloc(sizeof(DLinkList));
	L->pr = NULL;
	L->next = NULL;
}

//尾插法
DLinkList TailInsert(DLinkList& L, int t) {
	InitList(L);
	DNode* s, * r = L;
	int x;
	while (t--) {
		cin >> x;
		s = (DNode*)malloc(sizeof(DNode));
		s->data = x;
		s->next = NULL;
		s->pr = r;
		r->next = s;
		r = s;
	}
	return L;
}
//请勿复制粘贴,答案仅供参考
void search(DLinkList& L,int x) {
	DNode* p = L->next;
	while (true)
	{
		if (p == NULL) {
			break;
		}
		if (p->data == x && p->pr->pr != NULL && p->next != NULL) {
			cout << p->pr->data << " " << p->next->data << endl;
			return;
		}
		else if (p->data == x && p->pr->pr == NULL && p->next != NULL)
		{
			cout << p->next->data << endl;
			return;
		}
		else if (p->data == x && p->pr->pr != NULL && p->next == NULL)
		{
			cout << p->pr->data << endl;
			return;
		}
		p = p->next;
	}
}


int main() {
	int data, num, times, x;
	cin >> num >> times;
	DLinkList L = TailInsert(L,num);
	while (times--) {
		cin >> x;
		search(L, x);
	}
	return 0;
}
相关推荐
汉克老师1 小时前
GESP2024年6月认证C++二级( 第一部分选择题(9-15))
c++·循环结构·分支结构·gesp二级·gesp2级·求余数
清水白石0081 小时前
突破并行瓶颈:Python 多进程开销全解析与 IPC 优化实战
开发语言·网络·python
追随者永远是胜利者2 小时前
(LeetCode-Hot100)53. 最大子数组和
java·算法·leetcode·职场和发展·go
生成论实验室2 小时前
即事经:一种基于生成论的宇宙、生命与文明新范式
人工智能·科技·神经网络·算法·信息与通信
王老师青少年编程2 小时前
csp信奥赛c++高频考点假期集训(分模块进阶)
数据结构·c++·算法·csp·高频考点·信奥赛·集训
百锦再2 小时前
Java之Volatile 关键字全方位解析:从底层原理到最佳实践
java·开发语言·spring boot·struts·kafka·tomcat·maven
daad7773 小时前
rcu 内核线程
java·开发语言
z20348315203 小时前
如何通过状态机解决按键识别问题(二)
c语言·单片机·嵌入式硬件
xzjiang_3653 小时前
检查是否安装了MinGW 编译器
开发语言·qt·visual studio code
王老师青少年编程3 小时前
2020年信奥赛C++提高组csp-s初赛真题及答案解析(选择题1-5)
c++·题解·真题·初赛·信奥赛·csp-s·提高组