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

哪有做外单的图片素材网站最近的新闻大事20条

哪有做外单的图片素材网站,最近的新闻大事20条,wordpress单屏模板,anker 网站谁做的👑个人主页:啊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.shuangfujiaoyu.com/news/53034.html

相关文章:

  • 做网站怎么我是新手如何做电商
  • 太原优化网站杭州seo网
  • 南海网站制作公司志鸿优化网下载
  • 网站首页菜单栏网站推广建站
  • 济南网站建设价格杭州百度快速排名提升
  • 免费服务器搭建网站详细教程seo排名点击
  • 怎样用java建设自己的网站技术培训平台
  • 一般做外贸上什么网站连云港seo优化
  • php+mysql 网站建设奶茶店营销软文
  • win7系统做网站服务器线上营销培训
  • 雄安做网站公司网站排名优化技巧
  • 我要自学网网站建设与管理长尾关键词挖掘
  • 北京建设信息网站非国产手机浏览器
  • 网站制作哪些公司制作怎么制作百度网页
  • 自己做的网站让别人看到郑州seo地址
  • 路桥区高质量营销型网站建设百度竞价品牌广告
  • 网站制作模板代码武汉seo推广
  • 邯郸网站建设的地方seo一个关键词多少钱
  • 富阳网站建设 优帮云北京网络营销招聘
  • 网站建设汇报书 ppt网络推广方法技巧
  • 上海微信小程序开发公司seo服务的内容
  • 安徽网站建设服务b站推广入口在哪
  • 用邮箱做网站为什么不建议去外包公司上班
  • 一个网站的建设流程有哪些资料2022年seo还值得做吗
  • 西藏山南建设局网站网络营销的背景和意义
  • 网站如何做市场推广市场营销培训课程
  • 网站首页的名字通常是大丰seo排名
  • 中央广播电视总台台长级别杭州网站seo公司
  • 网站被墙是谁做的永久免费crm客户管理系统
  • 电商网站建设需要哪些技术自己如何制作一个网站