链表的回文结构,链表是一个什么结构

  链表的回文结构,链表是一个什么结构

  BM13判断一个链表是否是回文结构。

  知识点链表双指针

  给定一个链表,请判断这个链表是否是回文结构。回文是指字符串在正反顺序上完全一致。数据范围:链表中的节点数,链表中每个节点的值满足

  示例1输入:

  {1}复制返回值:

  准确的副本

  2示例输入:

  {2,1}复制返回值:

  虚假复印说明:

  2- 1示例3输入:

  {1,2,2,1}复制返回值:

  真实副本描述:

  1- 2- 2- 1

  解决方案想法:

  如果把链表换成数组,判断数组是不是回文就简单了。另外,如果我们能找到链表的中间节点,然后把后面的所有节点都倒过来,那么如果两个链表从链表的开头到结尾,直到相遇,其值都相等,那么也是一个回文。相应地,有以下方法:

  1.用数组存储所有节点,然后用数组回文判断链表是否回文。2.在stack的帮助下,将所有节点依次放入链表,然后将所有节点取出,依次与链表进行比较。3.反转链表,然后比较两个节点的所有值是否相等。4.找到中间节点,然后反转后面节点,再从第一个节点和中间节点判断所有值是否相等。以下是用array实现的:

  #包含位/标准数据。h

  结构列表节点

  {

  int val

  struct ListNode * next

  ListNode(int x) : val(x),next(nullptr)

  {

  }

  ListNode()=默认值;

  };

  bool isPail(ListNode *head)

  {

  STD:vector ListNode * v;

  自动节点=头;

  while(节点!=nullptr)

  {

  v.push_back(节点);

  node=node-next;

  }

  for(int I=0;I v . size()/2;我)

  {

  if (v[i]- val!=v[v.size() - 1 - i]- val)

  {

  返回false

  }

  }

  返回true

  }

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: