博客
关于我
链表7-链表的回文结构
阅读量:149 次
发布时间:2019-02-27

本文共 697 字,大约阅读时间需要 2 分钟。

题目描述

对于一个链表,请设计一个时间复杂度为O(n),额外空间复杂度为O(1)的算法,判断其是否为回文结构。

给定一个链表的头指针A,请返回一个bool值,代表其是否为回文结构。保证链表长度小于等于900。

测试样例:

1->2->2->1

返回:true

 

解题思路

快慢指针

反转链表

需要注意一点防止反转后链表成环的问题

 

 

class PalindromeList {public:	bool chkPalindrome(ListNode* A) {		ListNode*slow = A, *fast = A, *prev = NULL;//prev防止链表成环		while (fast&&fast->next)		{			prev = slow;			slow = slow->next;			fast = fast->next->next;		}		prev->next = NULL;//防止链表成环		ListNode*newhead = NULL, *cur = slow;		while (cur)		{			ListNode*next = cur->next;			cur->next = newhead;			newhead = cur;			cur = next;		}		slow = newhead;		while (A)		{			if (A->val != slow->val)				return false;			else			{				A = A->next;				slow = slow->next;			}		}		return true;	}};

 

转载地址:http://asbb.baihongyu.com/

你可能感兴趣的文章
Nancy之基于Nancy.Hosting.Aspnet的小Demo
查看>>
NAND NOR FLASH闪存产品概述
查看>>
nano 编辑
查看>>
nanoGPT 教程:从零开始训练语言模型
查看>>
NASA网站曝严重漏洞,或将沦为黑客钓鱼网站?
查看>>
Nash:轻量级、安全且可靠的脚本语言
查看>>
NAS、SAN和DAS的区别
查看>>
NAS个人云存储服务器搭建
查看>>
NAS服务器有哪些优势
查看>>
NAT PAT故障排除实战指南:从原理到技巧的深度探索
查看>>
nat 网卡间数据包转发_你是不是从来没有了解过光纤网卡,它跟普通网卡有什么区别?...
查看>>
NAT-DDNS内网穿透技术,快解析DDNS的优势
查看>>
NAT-DDNS内网穿透技术,快解析DDNS的优势
查看>>
NAT-DDNS内网穿透技术,解决动态域名解析难题
查看>>
natapp搭建外网服务器
查看>>
NativePHP:使用PHP构建跨平台桌面应用的新框架
查看>>
nativescript(angular2)——ListView组件
查看>>
NativeWindow_01
查看>>
Native方式运行Fabric(非Docker方式)
查看>>
Nature | 电子学“超构器件”, 从零基础到精通,收藏这篇就够了!
查看>>