当前位置: 首页 > news >正文

微信官方网站建设国外电商网站如何做icp备案

微信官方网站建设,国外电商网站如何做icp备案,百度一下你就知道了 官网,百度搜索数据查询链表的回文结构 一.链表的中间节点思路1:暴力求解思路2:快慢指针 二.返回倒数第k个节点思路1:暴力求解思路2:快慢指针 三.反转链表思路1:头插法思路2:反转指针的指向 四.链表的回文结构思路1:利…

链表的回文结构

  • 一.链表的中间节点
    • 思路1:暴力求解
    • 思路2:快慢指针
  • 二.返回倒数第k个节点
    • 思路1:暴力求解
    • 思路2:快慢指针
  • 三.反转链表
    • 思路1:头插法
    • 思路2:反转指针的指向
  • 四.链表的回文结构
    • 思路1:利用数组,判断是否回文
    • 思路2:求链表的中间节点+反转链表

要解决链表的回文结构:首先需要求中间节点,其次是会反转链表。

一.链表的中间节点

链表的中间节点
在这里插入图片描述

思路1:暴力求解

  1. 求出链表的长度。
  2. 求出要返回的中间节点的位置(除2+1),遍历链表返回节点指针即可。
  3. 注意:兼容奇数个节点与偶数个节点。
typedef struct ListNode ListNode;struct ListNode* middleNode(struct ListNode* head) 
{ListNode* cur = head;int listLength = 0; while(cur){//求链表的长度listLength++;cur = cur->next;}//链表中间节点的位置int middle = listLength / 2 + 1;int i = 1; //注意:非i=0cur = head;while(i < middle){i++;cur = cur->next;}return cur;
}

思路2:快慢指针

  1. 定义两个指针fast、slow保存链表头节点的地址。
  2. 进入循环,fast指针一次走两个节点,slow指针一次走一个节点,当fast != NULL && fast->next != NULL时循环继续,否则循环结束。

情况1.含有奇数个节点
在这里插入图片描述

情况2.含有偶数个节点

在这里插入图片描述

typedef struct ListNode ListNode;struct ListNode* middleNode(struct ListNode* head)
{//快慢指针:慢指针一次走一步,快指针一次走两步ListNode* fast = head;ListNode* slow = head;//注意循环继续的条件是&&而不是||,且fast与fast->next的位置不能交换while (fast != NULL && fast->next != NULL){fast = fast->next->next;slow = slow->next;}return slow;
}

二.返回倒数第k个节点

返回倒数第k个节点

在这里插入图片描述

思路1:暴力求解

  1. 遍历链表求链表的长度length
  2. 倒数第k个节点,等价于从前往后的第length - k个节点。
  3. 再次遍历链表找到第length - k个节点,返回节点指针即可。

在这里插入图片描述

typedef struct ListNode ListNode;int kthToLast(struct ListNode* head, int k)
{//1.遍历链表求出链表长度,再遍历一次链表,找到返回值int size = 0;ListNode* cur = head;while(cur){size++;cur = cur->next;}int i = 0;cur = head;while(i < size - k){cur = cur->next;i++;}return cur->val;
}

思路2:快慢指针

  1. 定义两个指针fast、slow保存链表头节点的地址。
  2. fast指针先走k个节点
  3. 进入循环,fast与slow指针各自每次走一个节点,当fast != NULL时循环继续,否则循环结束。

在这里插入图片描述

typedef struct ListNode ListNode;int kthToLast(struct ListNode* head, int k)
{//2.快慢指针:快指针先走k步,然后快指针一次走一步,慢指针一次走一步ListNode* fast = head;ListNode* slow = head;for (int i = 0; i < k; i++){fast = fast->next;}while (fast != NULL){fast = fast->next;slow = slow->next;}return slow->val;
}

三.反转链表

反转链表

思路1:头插法

  1. 创建新链表 newHead = NULL。
  2. 遍历原链表,逐个节点头插倒新链表中。

在这里插入图片描述

typedef struct ListNode ListNode;struct ListNode* reverseList(struct ListNode* head) 
{//1.创建新链表,遍历原链表,逐个头插ListNode* newHead = NULL, *cur = head;while(cur){//头插ListNode* next = cur->next;cur->next = newHead;newHead = cur;cur = next;}return newHead;
}

思路2:反转指针的指向

在这里插入图片描述

typedef struct ListNode ListNode;struct ListNode* reverseList(struct ListNode* head) 
{//2.创建三个指针,反转指针的指向if(head == NULL){return NULL;}ListNode* n1 = NULL, *n2 = head, *n3 = n2->next;while(n2){n2->next = n1;n1 = n2;n2 = n3;if(n3 != NULL){n3 = n3->next;}   }return n1;
}

四.链表的回文结构

链表的回文结构

思路1:利用数组,判断是否回文

class PalindromeList {
public://判断数组是否满足回文结构bool isReverse(int arr[], int left, int right){while(left < right){if(arr[left] != arr[right]){return false;}left++;right--;}return true;}bool chkPalindrome(ListNode* A){int arr[900];ListNode* cur = A;int i = 0, listLength = 0;while(cur){arr[i++] = cur->val;//将链表中的值保存到数组中cur = cur->next;listLength++;//求链表的长度}return isReverse(arr, 0, listLength - 1);}
};

思路2:求链表的中间节点+反转链表

  1. 寻找链表的中间节点 mid。
  2. 将中间节点 mid 以及之后的节点组成的链表反转。
  3. 遍历反转后的链表,当一个一个与原链表的数据域对比,若相同则是回文结构。

情况1.含有奇数个节点:
在这里插入图片描述
情况2.含有偶数个节点:

在这里插入图片描述

class PalindromeList {
public:ListNode* findMidNode(ListNode* phead){ListNode* fast = phead;ListNode* slow = phead;while(fast && fast->next){slow = slow->next;fast = fast->next->next;}return slow;}ListNode* reverseList(ListNode* phead){ListNode* n1, *n2, *n3;n1 = NULL, n2 = phead, n3 = n2->next;while(n2){n2->next = n1;n1 = n2;n2 = n3;if(n3 != NULL){n3 = n3->next;}         }return n1;}bool chkPalindrome(ListNode* A) {//1.找链表的中间节点ListNode* mid = findMidNode(A);//2.反转中间节点以及之后的节点组成的链表ListNode* right = reverseList(mid);//3.遍历反转链表,与原链表进制值的比较ListNode* left = A;while(right){if(right->val != left->val){return false;}right = right->next;left = left->next;}return true;}
};
http://www.yayakq.cn/news/629984/

相关文章:

  • 营销型网站制作公司桂林互联网企业
  • 有关建设网站的论文竹溪县县建设局网站
  • 二级域名网站优化推广平台文案
  • 怎么看百度指数网站视觉优化怎么做
  • 付费的网站是指东莞阳光网
  • wap手机网站建设制作开发盗号网站怎么做
  • 小说网站制作模板阿里云企业邮箱怎么申请
  • 做查工资的网站seo关键词分析
  • 湖南网站推广上海宣传片拍摄的公司
  • 有哪些网站做的好处域名买完了网站建设
  • 扬州广陵城乡建设局网站网站建设项目汇报
  • 网址怎么生成短链接郑州有没有厉害的seo顾问
  • 网站怎么做修改电子商务网站建设侧重哪几个方面
  • 网站如何发布和推广seo网络优化推广
  • 中国建设部网站四库平台关键词搜索量查询工具
  • 手机网站建设模板下载公众号 转 wordpress
  • 泉州建站模板网站佛山建网站费用
  • 少儿编程免费网站wordpress集成微博登陆
  • 高端的网站推广网站设计深圳联系电话?
  • 建设一个公司网站需要什么知识推广公司一般都怎么推广
  • 哪里有建网站的网站建设以及seo
  • 网站开发费用PHP网站建设选择哪家好
  • 毕业设计餐饮网站建设重庆舞台搭建招聘
  • 城乡与住房建设厅网站首页一个简单的动态页面网站需要数据库吗
  • 企业网站 设上饶高端网站建设
  • 企业网站建设经验家装设计师培训班多少钱一个月
  • 通过服务推广网站网站建设的7种流程图
  • 做灯箱的网站wordpress完全开源吗
  • 网上做翻译兼职网站表白制作网站
  • 潍坊网站模板在哪手工制作粽子