C++链表练习:英语单词的公共后缀(Common suffixes for English words)

时空限制

CPU占用时长: 1秒 内存使用限制: 128MB

问题描述

要存储英语单词,一种方法是使用链表并逐字母存储单词。为了节省空间,如果单词共享相同的后缀,我们可以让它们共享相同的子链表。例如,loading和being存储如下图所示。
,file,2024,01,20240124020330_图片1.png
现在你的任务就是找到公共后缀的起始位置(例如图中 i 的位置)

输入格式

输入第一行,包含两个结点地址和结点总数n(≤105) 。

接下来n行,每行描述一个结点:address data next

其中address是结点位置,data是该结点包含的大小写字母,next是下一个结点的位置;所有地址由5个数字构成,-1表示NULL。

输出格式

输出由5个数字构成,表示公共后缀的起始位置。如果没有公共后缀,则改输出-1。

输入输出样例

样例1

输入样例

11111 22222 9
67890 i 00002
00010 a 12345
00003 g -1
12345 D 67890
00002 n 00003
22222 B 23456
11111 L 00001
23456 e 67890
00001 o 00010

输出样例

67890

样例2

输入样例

00001 00002 4
00001 a 10001
10001 s -1
00002 a 10002
10002 t -1

输出样例

-1

参考代码

#include<bits/stdc++.h>
using namespace std;

struct node{
	char data; // 单词数据
	int next; // 指针
	bool flag;	//判断标记
};

int main(){
	const int N=100010;
    node L[N];
	int w1,w2,n;
    cin>>w1>>w2>>n;
	
    while(n--){
	int address,next;char data;
	cin>>address>>data>>next;		
	L[address]={data,next,false};
    }
    for(int p=w1;~p;p=L[p].next)
		L[p].flag=true; //遍历第1个单词	
    int p=w2;
	while(~p&&!L[p].flag)
		p=L[p].next; //遍历第2个单词                                                            
    if(~p)
		cout<<setw(5)<<p<<endl;else puts("-1");
	
    return 0;	
}	

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李老师信息奥赛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值