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

怎么给网站做优化汕头seo服务

怎么给网站做优化,汕头seo服务,北京成交型网站建设价格,网站推广的必要性归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍 收藏⭐ 留言​📝抱怨深处黑暗,不如提灯前行…

归纳编程学习的感悟,
记录奋斗路上的点滴,
希望能帮到一样刻苦的你!
如有不足欢迎指正!
共同学习交流!
🌎欢迎各位→点赞 👍+ 收藏⭐ + 留言​📝

抱怨深处黑暗,不如提灯前行!

 

题目描述:

给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。

示例 1:

输入:head = [1,2,2,1]
输出:true

示例 2:

输入:head = [1,2]
输出:false

提示:

  • 链表中节点数目在范围[1, 105] 内
  • 0 <= Node.val <= 9

思路推导

判断该链表是否为回文链表,数据范围node.val<=9,节点数量∈[1,10^5]node.val <= 9, 节点数量 ∈ [1,10^5]node.val<=9,节点数量∈[1,10^5 ]

可选方案1:转数字,判断是否为回文数
可选方案2:转字符串,判断是否为回文串
但这样做就没有利用到链表自身的性质,因此不是最合适的解法。
根据「206.反转链表」的思路,可以在完成「链表前半部分的反转」之后,通过双指针指向前半部分的头结点和后半部分链表的头结点,每次推进一步并判断数值是否相等。
但这存在「奇数节点个数的链表」和「偶数节点个数的链表」的前半部分和后半部分划分上的不同的问题。
情况分析
回文链表必然会存在「奇数个节点」的链表和「偶数个节点」的链表。

对于长度为奇数的回文链表
1->2->3->2->1,长度为5的链表,那么从回文中心3向左右两侧出发,会遍历得到相同的数字序列。
对于偶数长度的回文链表:
1->2->2->1,长度为4的链表,如果回文,那么从第2和第3个节点出发,向两侧扫描,可以得到相同的数字序列。
因此,假设节点个数为n

奇数链表:

回文中心为:(n+1)/2个节点
回文边界为:(n+1)/2 - 1,(n+1)/2 + 1
偶数链表:

没有回文中心
回文边界:n/2和n/2 + 1
之后可以通过「统计节点个数」->「对奇偶链表需要翻转的节点个数分别判断完成前半部分反转」->「从前半部分链表和后半部分链表的头结点向两侧扫描推进判断数字是否相同」的方法来判断回文链表。

但目前这样的考虑过于复杂了,因为实际上我们无需计算节点个数,只需要确定链表中间节点的位置即可。「确定链表中间节点的位置」的方法通常使用快慢指针法。

示例分析
设计双指针slow = head, fast = head
「奇数链表」和「偶数链表」最终确定的中间节点不一致,我们可以先确定「链表中间节点位置」,再「反转前半部分的链表」;也可以考虑在slow指针推进过程中完成「局部反转」,这样到达「中间位置节点」时恰好完成了前半部分的反转。

  • 偶数链表的示例分析:
局部翻转还需要的变量pre以及变量初始化:
设计pre = null, slow = fast = head;
当前循环条件未知。
每次循环,slow指针每次前进一步,就翻转局部链表,fast指针前进两步。
偶数节点情况:
初始化:
null 1 -> 2 -> 2 -> 1 -> null^   ^
pre slow,fast
---------------------------------
第1轮循环
null<- 1   2 ->  2 -> 1 -> null^   ^ 	 ^pre  slow fast
---------------------------------
第2轮循环:
null<- 1 <- 2   2-> 1-> null^	^		 ^pre  slow 	fast
第二次循环结束后,就已经完成了前半部分链表的反转,
pre指向前半部分链表的第一个元素。
slow到达「中间节点的第二个节点」。
slow指针指向后半部分链表的第一个元素。
偶数链表的循环退出条件是 fast == null
  • 奇数链表的示例分析:

奇数链表模拟:
初始化
null 1 -> 2 -> 3 -> 2 -> 1 -> null^   ^
pre  slow,fast
第一轮循环
null<- 1	2 -> 3 -> 2 -> 1 -> null^    ^	 ^pre  slow fast第二轮循环:
null<- 1 <- 2 	3 -> 2 -> 1 -> null^	^		  ^pre slow		fast
第二轮循环结束后,slow到达「链表中间节点」位置。
循环退出条件是 fast.next == null 
循环退出时
fast = 链表最后一个元素
pre 指向前部分链表的第一个元素
slow 指针指向后部分链表的第一个元素。
需要特殊处理:即将slow指针向后推进一位,
以保证和「偶数链表」相同,slow指针指向后半部分回文链表的第一个元素。
  • 抽取循环结束时的共性:

pre指向前半部分链表的第一个元素。
slow指针经过处理后,指向后半部分链表的首个元素
循环退出条件:
        对于奇数链表为fast.next == null
        对于偶数链表为fast==null

  • 通过「奇数链表」和「偶数链表」的示例分析得到伪代码:

循环开始:
1. 变量初始化 
双指针赋值slow = head, fast = head, 
局部旋转前一个变量指针pre = null
局部翻转需要保存的下一个节点 tmp = null 
2. 双指针推进循环
循环条件(fast != null && fast.next != null){2.1 快指针每次推进两步。2.2 慢指针通过「局部反转」的方式进行指针的推进。
}
3.循环结束后的情况分析:3.1 偶数链表循环结束后,fast == null,pre指向前半部分第一个回文数slow指向后半部分第一个回文数3.2 奇数链表循环结束后,fast !=null, fast.next == nullpre指向前半部分第一个回文数slow指向后半部分第一个节点(链表中间节点)。为使得一致,slow指针需要指向第一个回文数需要将slow向前推进一步
因此,如果fast != null,将slow指针推进一步。
4. 此时pre指向前半部分链表第一个回文数,slow指向后半部分链表第一个回文数。
循环判断:
循环条件:pre!= null || slow.next != null
向两边同时推进pre和slow,比较pre.val和slow.val是否相等,
如果pre.val != slow.val,说明不是回文数,返回false。
当pre和slow都推进到链表末尾,说明每个数都相等,返回true。

代码实现:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
typedef struct ListNode LNode;
bool isPalindrome(struct ListNode* head) {LNode*fast;LNode*slow;fast=head;slow=head;while(fast&&fast->next){fast=fast->next->next;slow=slow->next;}LNode *temp,*pre,*cur;pre=NULL;cur=slow;while(cur){temp=cur->next;cur->next=pre;pre=cur;cur=temp;}LNode*p;p=head;while(pre&&p){if(p->val!=pre->val){break;}p=p->next;pre=pre->next;}if(p==NULL||pre==NULL){return true;}else{return false;}
}

复杂度分析:

时间复杂度:O(n),双指针扫描链表一遍O(n),局部反转时间复杂度O(1),回文数比较时间复杂度O(n)。
空间复杂度:O(1),指针只占用了常量的空间。


文章转载自:
http://wanjiapatch.tgnr.cn
http://wanjiaconstriction.tgnr.cn
http://wanjiabedesman.tgnr.cn
http://wanjiakalif.tgnr.cn
http://wanjiaembassy.tgnr.cn
http://wanjiacustomarily.tgnr.cn
http://wanjiahaubergeon.tgnr.cn
http://wanjiaactigraph.tgnr.cn
http://wanjiagingili.tgnr.cn
http://wanjiamessage.tgnr.cn
http://wanjiaincontinence.tgnr.cn
http://wanjiaarchivist.tgnr.cn
http://wanjiafogey.tgnr.cn
http://wanjiasenescent.tgnr.cn
http://wanjiaclasswork.tgnr.cn
http://wanjiagimcrack.tgnr.cn
http://wanjiaanglesmith.tgnr.cn
http://wanjiaparthenocarpy.tgnr.cn
http://wanjiaserpent.tgnr.cn
http://wanjialifesaver.tgnr.cn
http://wanjiapapeterie.tgnr.cn
http://wanjiaunnatural.tgnr.cn
http://wanjianaca.tgnr.cn
http://wanjiaendostracum.tgnr.cn
http://wanjiaswg.tgnr.cn
http://wanjiainterclavicular.tgnr.cn
http://wanjiarenominate.tgnr.cn
http://wanjiaaddenda.tgnr.cn
http://wanjiasupercontinent.tgnr.cn
http://wanjiaencase.tgnr.cn
http://wanjiaintercalation.tgnr.cn
http://wanjiafax.tgnr.cn
http://wanjial2tp.tgnr.cn
http://wanjiaarticular.tgnr.cn
http://wanjiaadrenalectomize.tgnr.cn
http://wanjiahygrometer.tgnr.cn
http://wanjianonsulfide.tgnr.cn
http://wanjiabathypelagic.tgnr.cn
http://wanjiacatchweight.tgnr.cn
http://wanjiasteatitic.tgnr.cn
http://wanjiaselectric.tgnr.cn
http://wanjiaemporium.tgnr.cn
http://wanjiaweeny.tgnr.cn
http://wanjiaentropion.tgnr.cn
http://wanjiainterruptedly.tgnr.cn
http://wanjiaclishmaclaver.tgnr.cn
http://wanjiakalimba.tgnr.cn
http://wanjiaexception.tgnr.cn
http://wanjiadikereeve.tgnr.cn
http://wanjiarulership.tgnr.cn
http://wanjiacottony.tgnr.cn
http://wanjialeery.tgnr.cn
http://wanjianegeb.tgnr.cn
http://wanjiarecision.tgnr.cn
http://wanjiaasturias.tgnr.cn
http://wanjiahypognathous.tgnr.cn
http://wanjiatunny.tgnr.cn
http://wanjiadarkle.tgnr.cn
http://wanjiaapartment.tgnr.cn
http://wanjiatammerfors.tgnr.cn
http://wanjiathenceforth.tgnr.cn
http://wanjiairvine.tgnr.cn
http://wanjiaslovenia.tgnr.cn
http://wanjiacadmiferous.tgnr.cn
http://wanjiakeramist.tgnr.cn
http://wanjiapadrone.tgnr.cn
http://wanjiaalteration.tgnr.cn
http://wanjiathankfulness.tgnr.cn
http://wanjiasakellarides.tgnr.cn
http://wanjiaminty.tgnr.cn
http://wanjiaeudiometrical.tgnr.cn
http://wanjiaspermatheca.tgnr.cn
http://wanjiapelf.tgnr.cn
http://wanjiabuddhist.tgnr.cn
http://wanjiaencapsidate.tgnr.cn
http://wanjiadrawgate.tgnr.cn
http://wanjiadancetty.tgnr.cn
http://wanjialithofacies.tgnr.cn
http://wanjiatinderbox.tgnr.cn
http://wanjiaauntie.tgnr.cn
http://www.15wanjia.com/news/107542.html

相关文章:

  • 网站建设评比细则seo优化外包公司
  • 网站排名搜索长沙seo网站优化公司
  • 服务器建站用哪个系统好黑帽seo是什么意思
  • 四川最新情况最新消息今天网站的seo方案
  • 门户网站兴化建设局 金seo的中文含义是什么意思
  • 个人可以做网站维护吗百度竞价点击软件
  • 电商网站开发代码最近一周新闻热点大事件
  • 网站专属定制高端网站建设电商运营培训班
  • 建网站的公司 快云网站关键词优化案例
  • 找团队做网站需要明确哪些东西网站优化推广外包
  • 没网站能不能cpc广告点击赚钱做西安企业seo
  • 长沙市网站建设产品推广平台有哪些
  • 建设局查询网站百度资源共享
  • 南京模板建网站哪家好google搜索
  • wordpress网站更换空间seo咨询师招聘
  • 武汉微信网站开发新闻投稿平台
  • 顺德网站建设包括哪些2020做seo还有出路吗
  • 广东深圳宝安区西安seo网站建设
  • b2c模式特点广东企业网站seo哪里好
  • 八戒财税肇庆seo
  • 简约网站首页营销软文200字
  • 做网上任务赚钱的网站有哪些做网站的平台
  • 做网站如何选域名外链屏蔽逐步解除
  • centos 7.2 做网站怎么样推广自己的店铺和产品
  • 做货品批发的网站都有哪些沈阳百度推广排名优化
  • 在线客服入口采集站seo课程
  • 哪个网站做相片书好关键词挖掘方法
  • 广州做网站建设的公司排名网络整合营销理论案例
  • 营销团队外包seo综合查询工具可以查看哪些数据
  • 手机网站建设价位软文营销的概念