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

长安建网站公司网站建设文字设计

长安建网站公司,网站建设文字设计,建设网站收取广告费用,现在企业做门户网站👑个人主页:啊Q闻 🎇收录专栏:《数据结构》 🎉前路漫漫亦灿灿 前言 今日的习题是关于链表的,分别是链表的回文结构和相交链表的判断。 链表的回文结构 题目为:链表的回文结…

 👑个人主页:啊Q闻       

🎇收录专栏:《数据结构》           

 🎉前路漫漫亦灿灿

前言 

今日的习题是关于链表的,分别是链表的回文结构和相交链表的判断。

链表的回文结构 

题目为:链表的回文结构_牛客题霸_牛客网

这道题目没有C语言的运行环境,我们可以用C++,C++兼容C

思路为: 

 我们实现判断是否为回文结构,要先找到中间节点,然后将中间节点开始的后部分逆置,所以我们要调用前面学习过的寻找中间节点和反转链表的函数【数据结构】链表习题之链表的中间节点和合并两个有序链表-CSDN博客

【数据结构】链表习题之反转链表和删除链表中等于给定值 val 的所有节点-CSDN博客

然后比较后半部分和前半部分,判断是否相同。

代码实现:

struct ListNode*reverse(struct ListNode*head)//反转链表
{if(head==NULL){return head;}struct ListNode*n1,*n2,*n3;n1=NULL;n2=head;n3=head->next;while(n2){n2->next=n1;n1=n2;n2=n3;if(n3){n3=n3->next;}}return n1;
}
struct ListNode*middleNode(struct ListNode*head)//寻找中间节点
{struct ListNode*slow,*fast;slow=fast=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;}return slow;
}
class PalindromeList {
public:bool chkPalindrome(ListNode* A) {struct ListNode*mid=middleNode(A);//将节点后部分逆置struct ListNode*rmid=reverse(mid);while(A&&rmid)//比较两部分,当有一个为空时,循环结束{if(A->val!=rmid->val){return false;}A=A->next;rmid=rmid->next;}return true;}
};

相交链表 

题目为:. - 力扣(LeetCode)

思路为:

注意:我们比较的是节点的指针,而不是节点的值,因为节点不相交的时候,其节点的值也有可能相等。 

我们可以先找A和B链表的尾节点,如果尾节点相同,则代表这两个链表一定相交,然后我们再求长度差,让长的链表先走长度差,长的链表走完长度差后,A和B两个链表再一起走。


时间复杂度分析:我们利用这种方法,其时间的复杂度为:遍历A链表为N,遍历B链表为N,然后减去长度差后再一起遍历为N,N+N+N=3N,即O(N)。


在这个代码的实现过程中,我们会用到假设法,来简化长短链表的判断,是一个很实用的方法。

代码实现:

struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {struct ListNode*curA=headA;struct ListNode*curB=headB;int lenA=0;int lenB=0;while(curA->next)//A和B链表遍历找尾节点{++lenA;curA=curA->next;}while(curB->next){++lenB;curB=curB->next;}if(curA!=curB){return NULL;}int gap=abs(lenA-lenB);//abs为绝对值//假设法:假设A为长链表,B为短链表,然后再利用一个判断,不成立就交换struct ListNode*longlist=headA;struct ListNode*shortlist=headB;if(lenA<lenB){longlist=headB;shortlist=headA;}while(gap--)//长链表先走{longlist=longlist->next;}while(longlist!=shortlist)//A和B链表一起走{longlist=longlist->next;shortlist=shortlist->next;}return longlist;//该处返回长短链表均可
}

详解:

假设法:我们用假设法,就可以不用分别去讨论A>B,还是A<B,简化了代码

😃感谢大家阅读,希望对你有帮助😄

如果对你有帮助的话,三连支持一下吧

http://www.yayakq.cn/news/964259/

相关文章:

  • 德阳市做网站网站建设口号
  • 免费行情网站大全珠海网站建设
  • 扬州专业外贸网站建设推广世界十大电商平台
  • 酒店网站策划e龙岩官网下载电脑版
  • 如何做简洁网站三站合一的网站怎么做教程
  • 网站要钱怎么网站商城运营模式
  • 便宜的广州网站建设服务重庆住建网站
  • 建设网站花都拱墅抖音seo搜索排名推广
  • 怎么建立企业网站平台山东建设厅网站是什么
  • 网站建设平台简介常州钟楼区邹区建设局网站
  • 企业免费网站推广公司湖南北山建设集团网站
  • 前端做微网站用照片做视频的网站好
  • 山东省住房和城乡建设厅官方网站网站建设与管理就业岗位
  • 不会代码可不可以做网站可爱风格网站
  • 白鹭引擎做h5网站互联网营销师证
  • 门户网站建设工作流程广州seo关键词优化费用
  • 做购物网站建设的公司南京网站设计的公司
  • 中山公众号平台商场网站建设做内容网站赚钱吗
  • 给帅哥做奴视频网站qq群推广
  • 网站怎么验证用户是否登陆安阳县辛村镇
  • seo入门培训学校苏州seo公司排名
  • 宝塔如何搭建网站如何把网站扒下来
  • 南京专业网站设计公司网站关闭多久排名会下降
  • 嵌入字体的网站wordpress页面相册
  • 定制网站开发费用多少vs2010网站开发视频
  • wordpress无域名建站磁力库
  • 网站可以用cdr做吗中国前十名别墅装修公司
  • 模拟网站开发微信公众号登录入口在哪里
  • 扶风网站开发济南手机端建站模板
  • seo网站优化外包公司网站维护如何上图