• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C++数据结构与算法之判断一个链表是否为回文结构的方法

C++数据结构与算法之判断一个链表是否为回文结构的方法

作者:难免有错_ 字体:[增加 减小] 来源:互联网 时间:2017-05-28

难免有错_ 通过本文主要向大家介绍了链表c++,c++链表的创建,c++链表类,c++链表教程,c++单链表等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了C++判断一个链表是否为回文结构的方法。分享给大家供大家参考,具体如下:

题目:

给定一个链表头节点head,请判断是否为回文结构

例如:

1->2->1 true
1->2->2->1 true
1->2->3->4->2->1 false

解题思路及代码

1、找到链表中间节点,然后将链表中间节点的右边所有节点放入一个栈中。

2、然后从链表首节点和栈顶元素一一对比,不相等则return false。

算法C++代码:

链表节点结构定义

typedef struct Node
{
  int data;
  struct Node* next;
}node, *pLinkedList;
</div>
bool isHuiWen(pLinkedList head)
{
  if (head == NULL || head->next == NULL)
    return true;
  pLinkedList right = head->next;//保存中间节点的下一个节点(若为偶数则为偏右的中间节点)
  pLinkedList cur = head;      //快指针
  while (cur->next != NULL && cur->next->next != NULL)
  {
    right = right->next;
    cur = cur->next->next;
  }
  //当链表总结点个数为奇数情况时:
  if (cur->next != NULL && cur->next->next == NULL)
    right = right->next;
  //将链表右边的节点放入一个栈中
  stack<pLinkedList>* s = new stack<pLinkedList>();
  while (right != NULL)
  {
    s->push(right);
    right = right->next;
  }
  //比较链表左右两边节点是否相等
  while (!s->empty())
  {
    if (head->next->data != s->top()->data)
      return false;
    s->pop();
    head = head->next;
  }
  return true;
}

</div>

希望本文所述对大家C++程序设计有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C++实现打印两个有序链表公共部分的方法
  • C++删除链表中间节点的方法
  • C++数据结构与算法之判断一个链表是否为回文结构的方法
  • 用C++类实现单向链表的增删查和反转操作方法
  • C++实现接两个链表实例代码
  • C++ 单链表的基本操作(详解)
  • C++ 双链表的基本操作(详解)
  • C++链表倒序实现方法
  • c++双向链表操作示例(创建双向链、双向链表中查找数据、插入数据等)
  • 如何用C++实现双向循环链表

相关文章

  • 2017-05-28使用C语言解决字符串匹配问题的方法
  • 2017-05-28C++获取任务栏打开程序窗口示例
  • 2017-05-28编译错误error: stray ‘\343’in program的解决方法
  • 2017-05-28C语言中多维数组的内存分配和释放(malloc与free)的方法
  • 2017-05-28Windows网络编程之winsock实现文件传输示例
  • 2017-05-28解析ActiveMQ的使用说明总结
  • 2017-05-28C语言的语法风格与代码书写规范指南
  • 2017-05-28C++实现随机生成迷宫地牢
  • 2017-05-28c++中#include &lt;&gt;与#include""的区别详细解析
  • 2017-05-28C语言使用openSSL库DES模块实现加密功能详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C++实现判断字符串是否回文实例解析
    • 简明的C++函数指针学习教程
    • 解析C/C++中如何终止线程的运行
    • 学习C和C++的9点经验总结
    • VC6.0常见链接错误与解决方法
    • C语言动态数组的使用实现代码
    • C++程序中使用Windows系统Native Wifi API的基本教程
    • C语言求两个字符串的最长公共子串
    • C语言编写Linux守护进程实例
    • 用while判断输入的数字是否回文数的简单实现

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有