求相同后缀起始位置:2012年408算法题

题目

算法思想

  1. 分别求出两个链表的长度len1和len2
  2. 将两个链表以表尾对齐:令指针 p、q 分别指向 str1 和 str2 的头结点,根据len1和len2的长度大小,使指针 p 和 q 所指的结点到表尾的长度相等
  3. 反复将指针 p 和 q 同步向后移动,并判断它们是否指向同一结点。若 p 和 q 指向同一结点,则该点即为所求的共同后缀的起始位置

算法实现

int LengthOfList(Node* L) {
	int len = 0;
	while (L->next != NULL) {
		L = L->next;
		len++;
	}
	return len;
}

Node* findCommonSuffix(Node* L1, Node* L2) {
	int len1 = LengthOfList(L1);
	int len2 = LengthOfList(L2);
	Node* p, * q;
	for (p = L1;len1 > len2 ; len1--)
	{
		p = p->next;
	}
	for (q = L2; len1 < len2; len2--)
	{
		q = q->next;
	}

	while(p!=NULL && p!=q)
	{
		p = p->next;
		q = q->next;
	}
	return p;
}

时间复杂度

时间复杂度为:O(len1+len2),其中 len1、len2 分别为两个链表的长度。即求两个链表长度的时间复杂度之和

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值