博客
关于我
链表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/

你可能感兴趣的文章
Netflix:当你按下“播放”的时候发生了什么?
查看>>
Netflix推荐系统:从评分预测到消费者法则
查看>>
netframework 4.0内置处理JSON对象
查看>>
Netgear WN604 downloadFile.php 信息泄露漏洞复现(CVE-2024-6646)
查看>>
Netgear wndr3700v2 路由器刷OpenWrt打造全能服务器(十一)备份
查看>>
netlink2.6.32内核实现源码
查看>>
netmiko 自动判断设备类型python_Python netmiko模块的使用
查看>>
NetMizer 日志管理系统 多处前台RCE漏洞复现
查看>>
NetMizer-日志管理系统 dologin.php SQL注入漏洞复现(XVE-2024-37672)
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
netron工具简单使用
查看>>
NetScaler MPX Gateway Configuration
查看>>
NetScaler的常用配置
查看>>
netsh advfirewall
查看>>
NETSH WINSOCK RESET这条命令的含义和作用?
查看>>
netstat kill
查看>>
netstat命令用法详解
查看>>
Netstat端口占用情况
查看>>
Netty 4的内存管理:sun.misc.Unsafe
查看>>
Netty channelRegistered\ChannelActive---源码分析
查看>>