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

网站线上投票怎样做互联网推广有哪些方式

网站线上投票怎样做,互联网推广有哪些方式,网站做贷款许可证,乌拉圭网站后缀判断一个链表是否为回文结构 题目链接:判断一个链表是否为回文结构 解题思路1:借助数组 遍历链表将值都放在数组中,再遍历数组元素,判断该数组是否为一个回文结构 代码如下: bool isPail(ListNode* head) {ListNod…

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

题目链接:判断一个链表是否为回文结构

解题思路1:借助数组

遍历链表将值都放在数组中,再遍历数组元素,判断该数组是否为一个回文结构

代码如下:

    bool isPail(ListNode* head) {ListNode* cur = head;vector<int> v;while(cur != nullptr){v.push_back(cur->val);cur = cur->next;}for(int i=0,j=v.size()-1; i<j; ++i,--j){if(v[i] != v[j]){return false;}}return true;}

解题思路2:反转部分链表进行对比

注意不能反转全部的链表,否则链表整个结构都改变了,再想和初始的链表进行对比的时候,发现最初的链表已经找不到了,原来的head的next为空了,原来的结构不复存在,所以强调反转部分链表

首先遍历链表,统计链表的长度
将长度除以2,从头节点开始走这么多的位置,找到中间位置
从中间位置开始,对链表进行反转
用双指针一个从头,一个从反转的部分链表的头开始依次比较对应位置的元素值是否相等

代码如下:

    ListNode* reverse(ListNode* head){ListNode* res = nullptr;ListNode* pre = nullptr;ListNode* cur = head;while(cur != nullptr){ListNode* temp = cur->next;if(cur->next == nullptr) res = cur;cur->next = pre;pre = cur;cur = temp;}return res;}bool isPail(ListNode* head) {ListNode* p = head;int n = 0;while(p != nullptr){p = p->next;n++;}n = n / 2;p = head;while(n > 0){p = p->next;n--;}p = reverse(p);ListNode* q = head;while(p != nullptr){if(p->val != q->val) return false;p = p->next;q = q->next;}return true;}

解题思路3:利用快慢指针找中点

慢指针每次走一个节点,快指针每次走两个节点,快指针到达链表尾的时候,慢指针刚好走到了链表中点
从中点的位置 ,开始将后半段链表反转
左右双指针,左指针从链表头开始往后遍历,右指针从链表尾往反转后的链表遍历,依次比较遇到的值

代码如下:

    ListNode* reverse(ListNode* head){ListNode* res = nullptr;ListNode* pre = nullptr;ListNode* cur = head;while(cur != nullptr){ListNode* temp = cur->next;if(cur->next == nullptr) res = cur;cur->next = pre;pre = cur;cur = temp;}return res;}bool isPail(ListNode* head) {ListNode* slow = head;ListNode* fast = head;//双指针找中点while(fast != nullptr && fast->next != nullptr){slow = slow->next;fast = fast->next->next;}//中点处反转slow = reverse(slow);fast = head;while(slow != nullptr){if(slow->val != fast->val) return false;fast = fast->next;slow = slow->next;} return true;}

解题思路4:栈逆序

将元素放到栈中,再依次取出栈顶元素和链表进行对比,如果都相同,那该链表就是回文链表

    bool isPail(ListNode* head) {stack<int> st;ListNode* cur = head;while(cur != nullptr){st.push(cur->val);cur = cur->next;}cur = head;while(!st.empty()){if(cur->val != st.top()) return false;st.pop();cur = cur->next;}return true;}
http://www.dinnco.com/news/3928.html

相关文章:

  • 站酷设计网南京seo优化
  • 如何做好网站管理工作关键词首页排名代做
  • 网站一般建什么网络推广平台软件
  • 怎么给公司做网站推广免费网站建站2773
  • 桂林网站设计电脑培训网上课程
  • 网站建设基本流程站长之家关键词挖掘工具
  • 做网站设计收入b站推广在哪里
  • 推广app赚佣金平台有哪些深圳百度seo整站
  • 网站制作与发布什么是网站推广优化
  • 泰州网站制作公司网站优化基本技巧
  • 网站域名的所有权一站式发稿平台
  • 网站建设公司排名手机百度app安装下载
  • 月夜直播免费完整版seo外链收录
  • 自学网ps教程新手入门百度seo查询系统
  • wordpress.conf优化最狠的手机优化软件
  • 今日要闻10条常州网络推广seo
  • 济宁企业做网站网络推广营销方法
  • 网站的项目建设周期企业管理培训班
  • 长春本地网站制作搜索引擎优化seo专员
  • 北京商地网站建设公司新闻头条最新消息10条
  • 重庆中色十二冶金建设有限公司网站系统优化大师官方下载
  • 中国建设银行官网站查询卡号最新网络营销方式有哪些
  • 安庆做网站赌博代理免费网站建设制作
  • 信阳网站优化中国十大小说网站排名
  • 哈尔滨建工建设集团怎么优化
  • 天门seoseo人员培训
  • .vip域名做网站以下哪个单词表示搜索引擎优化
  • 企业网站开发论文总结服务推广软文
  • 德州哪里有做网站的在线资源链接
  • 网站登录不上去怎么回事软文营销广告案例