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

怎么做英文版的网站网络销售平台有哪些软件

怎么做英文版的网站,网络销售平台有哪些软件,东城手机网站制作,网站域名是不是网址单链表OJ题 前言一、删除链表中等于给定值 val 的所有节点二、反转一个单链表三、返回链表的中间结点四、输出该链表中倒数第k个结点五、将两个有序链表合并六、链表的回文结构七、将链表分割成两部分八、找出第一个公共结点九、判断链表中是否有环总结 前言 在前面的博客中我…

在这里插入图片描述

单链表OJ题

  • 前言
  • 一、删除链表中等于给定值 val 的所有节点
  • 二、反转一个单链表
  • 三、返回链表的中间结点
  • 四、输出该链表中倒数第k个结点
  • 五、将两个有序链表合并
  • 六、链表的回文结构
  • 七、将链表分割成两部分
  • 八、找出第一个公共结点
  • 九、判断链表中是否有环
  • 总结


前言

在前面的博客中我们知道了什么是单链表以及如何建立单链表!
现在让我们来检验一下学习成果吧!

提示:此博客中题目均来自牛客网以及力扣网!在题目中我会附带两大网站的链接,大家也可以去练习一下!
若有链接问题可以在评论区及时反馈!


一、删除链表中等于给定值 val 的所有节点

题目链接:OJ链接
在这里插入图片描述

提示:
列表中的节点数目在范围 [0, 104] 内
1 <= Node.val <= 50
0 <= val <= 50

思路解析:
在这里插入图片描述

代码演示:

struct ListNode* removeElements(struct ListNode* head, int val) {struct ListNode* newhead = NULL;struct ListNode* move = head;struct ListNode* tail = NULL;while (move != NULL) {if (move->val != val) {if (tail == NULL) {//如果newnode为NULL,则tail等于newnode,则直接将结点地址赋予tailnewhead = tail = move;move = move->next;}else {tail->next = move;move = move->next;tail = tail->next;}}else {struct ListNode* temp = move;//新建结点保存要free的地址,以免free后造成节点丢失move = move->next;free(temp);}}if (tail)//如果新链表不为空,则将其尾结点的next置空tail->next = NULL;return newhead;}

二、反转一个单链表

题目链接:OJ链接
在这里插入图片描述
在这里插入图片描述

提示:
链表中节点的数目范围是 [0, 5000]
-5000 <= Node.val <= 5000

思路解析:
在这里插入图片描述

代码演示:

struct ListNode* reverseList(struct ListNode* head) {struct ListNode* move1 = head;struct ListNode* tail = head;if (head == NULL || head->next == NULL) {//如果链表为空或者只有一个结点,则不需要反转return tail;}struct ListNode* move2 = move1->next;while (move2) {struct ListNode* temp = move2->next;//保存下一个结点的地址,防止后面的节点丢失move2->next = move1;move1 = move2;move2 = temp;}tail->next = NULL;//尾结点的next置空struct ListNode* newhead = move1;//move1最后指向了反转链表的起始结点return newhead;
}

三、返回链表的中间结点

题目链接:OJ链接
在这里插入图片描述

提示:
链表的结点数范围是 [1, 100]
1 <= Node.val <= 100

思路解析:
在这里插入图片描述

代码演示:

struct ListNode* middleNode(struct ListNode* head){struct ListNode*move1=head;struct ListNode*move2=head;while(move2!=NULL&&move2->next!=NULL){//此处move2!=NULL和move2->next!=NULLmove1=move1->next;                //的位置不能交换,否则会造成空指针错误move2=move2->next->next;}return move1;
}

四、输出该链表中倒数第k个结点

题目链接:OJ链接
在这里插入图片描述
思路解析:
在这里插入图片描述

代码演示:

struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) {struct ListNode*move1=pListHead;struct ListNode*move2=pListHead;int i=k;while(i>0&&move2!=NULL){//move2向后移动k位move2=move2->next;i--;}if(move2==NULL&&i>0){//如果k大于链表结点数目,则返回NULLreturn move2;}while(move2){move1=move1->next;move2=move2->next;}return move1;
}

五、将两个有序链表合并

题目链接:OJ链接
在这里插入图片描述
在这里插入图片描述

提示:
两个链表的节点数目范围是 [0, 50]
-100 <= Node.val <= 100
l1 和 l2 均按 非递减顺序 排列

思路解析:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码演示:

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){struct ListNode*move1=list1;struct ListNode*move2=list2;struct ListNode*newnode=NULL;struct ListNode*tail=NULL;while(move1!=NULL&&move2!=NULL){if(move1->val<=move2->val){if(tail==NULL){{//如果newnode为NULL,则tail等于newnode,则直接将结点地址赋予tailnewnode=tail=move1;move1=move1->next;}else{tail->next=move1;move1=move1->next;tail=tail->next;}}else{if(tail==NULL){//如果newnode为NULL,则tail等于newnode,则直接将结点地址赋予tailnewnode=tail=move2;move2=move2->next;}else{tail->next=move2;move2=move2->next;tail=tail->next;}}}if(move1==NULL){//如果链表1遍历完而链表2没有,则将链表2剩余结点尾插到newnode中while(move2!=NULL){if(tail==NULL){//如果newnode为NULL,则tail等于newnode,则直接将结点地址赋予tailnewnode=tail=move2;move2=move2->next;}else{tail->next=move2;move2=move2->next;tail=tail->next;}}}if(move2==NULL){//如果链表2遍历完而链表1没有,则将链表1剩余结点尾插到newnode中while(move1!=NULL){if(tail==NULL){//如果newnode为NULL,则tail等于newnode,则直接将结点地址赋予tailnewnode=tail=move1;move1=move1->next;}else{tail->next=move1;move1=move1->next;tail=tail->next;}}}return newnode;
}

六、链表的回文结构

题目链接:OJ链接

在这里插入图片描述
思路解析:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码演示:

bool chkPalindrome(struct ListNode* A) {struct ListNode* move1 = A;struct ListNode* move2 = A;struct ListNode* move3 = A;struct ListNode* newnode = NULL;struct ListNode* tail = NULL;while (move2 != NULL&&move2->next != NULL ) {//找到中间节点move1 = move1->next;move2 = move2->next->next;}if (move2 == NULL);//如果节点个数为奇数,则move1向后移动一位else {move1 = move1->next;}while (move1 != NULL) {//将后半段链表头插到newnode中if (newnode == NULL) {newnode = tail = move1;move1 = move1->next;tail->next = NULL;}else {struct ListNode* temp = move1->next;move1->next = newnode;newnode = move1;move1 = temp;}}struct ListNode* cmp = newnode;while (move3 != NULL && cmp != NULL) {//比较原链表前半段和newnode是否相同if (move3->val != cmp->val) {return 0;}else {move3 = move3->next;cmp = cmp->next;}}return 1;
}

七、将链表分割成两部分

题目链接:OJ链接
在这里插入图片描述
思路解析:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

代码演示:

ListNode* partition(ListNode* pHead, int x) {struct ListNode*head1=(struct ListNode*)malloc(sizeof(struct ListNode));struct ListNode*head2=(struct ListNode*)malloc(sizeof(struct ListNode));struct ListNode*tail1=head1;struct ListNode*tail2=head2;struct ListNode*move=pHead;while(move){if(move->val<x){tail1->next=move;move=move->next;tail1=tail1->next;}else{tail2->next=move;move=move->next;tail2=tail2->next;}}tail2->next=NULL;//将尾指针的next置空tail1->next=head2->next;struct ListNode*temp1=head1;struct ListNode*temp2=head2;head1=head1->next;//指针指向头结点的下一节点free(temp1);//释放掉创建的头结点free(temp2);return head1;}

八、找出第一个公共结点

题目链接:OJ链接
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

注意:
函数返回结果后,链表必须 保持其原始结构 。

思路解析:
在这里插入图片描述
在这里插入图片描述

代码演示:

struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {struct ListNode *move1=headA;struct ListNode *move2=headB;int len1=1,len2=1;while(move1){//得到链表A的长度move1=move1->next;len1++;}while(move2){//得到链表B的长度move2=move2->next;len2++;}int k=abs(len1-len2);//取相减的绝对值struct ListNode *moveA=headA;struct ListNode *moveB=headB;if(len1>len2){//较长的链表走k步while(k--){moveA=moveA->next;}}if(len1<len2){while(k--){moveB=moveB->next;}}while(moveA&&moveB){if(moveA==moveB)return moveA;//若地址相同则返回moveA=moveA->next;moveB=moveB->next;}return NULL;

九、判断链表中是否有环

题目链接:OJ链接
在这里插入图片描述
在这里插入图片描述

提示:

链表中节点的数目范围是 [0, 104]
-105 <= Node.val <= 105
pos 为 -1 或者链表中的一个 有效索引 。

思路解析:
在这里插入图片描述

代码演示:

bool hasCycle(struct ListNode *head) {struct ListNode*move1=head;struct ListNode*move2=head;while(move1&&move2&&move2->next){//此处move2和move2->next的顺序不可交换move1=move1->next;           //否则会导致空指针错误move2=move2->next->next;if(move1==move2)return true;}return false;
}

总结

这九道单链表OJ都是我见过的很经典的题型!
在这里为大家分享一下!
希望有更多的人能够通过这些题目更好地掌握单链表相关的知识!


文章转载自:
http://dinncoinsociable.tqpr.cn
http://dinncocretinism.tqpr.cn
http://dinncoleucomaine.tqpr.cn
http://dinncoassassinator.tqpr.cn
http://dinncotenace.tqpr.cn
http://dinncopontifices.tqpr.cn
http://dinncogallerygoer.tqpr.cn
http://dinncoklick.tqpr.cn
http://dinncovestment.tqpr.cn
http://dinncowraac.tqpr.cn
http://dinncohls.tqpr.cn
http://dinncodiane.tqpr.cn
http://dinncoraw.tqpr.cn
http://dinncopunty.tqpr.cn
http://dinncooh.tqpr.cn
http://dinncourinose.tqpr.cn
http://dinncophotomicroscope.tqpr.cn
http://dinncoannelida.tqpr.cn
http://dinncosatiable.tqpr.cn
http://dinncoagriculturalist.tqpr.cn
http://dinnconucleolus.tqpr.cn
http://dinnconiocalite.tqpr.cn
http://dinncogermicidal.tqpr.cn
http://dinncodowntonian.tqpr.cn
http://dinncoouttrick.tqpr.cn
http://dinncocoloquintida.tqpr.cn
http://dinncomelilla.tqpr.cn
http://dinncodividual.tqpr.cn
http://dinncofurriery.tqpr.cn
http://dinncopseudoparenchyma.tqpr.cn
http://dinncosundriesman.tqpr.cn
http://dinncodidapper.tqpr.cn
http://dinncohalogenation.tqpr.cn
http://dinncohispanism.tqpr.cn
http://dinncoerythritol.tqpr.cn
http://dinncounswayable.tqpr.cn
http://dinncoportreeve.tqpr.cn
http://dinncogrove.tqpr.cn
http://dinncopandean.tqpr.cn
http://dinncomediatize.tqpr.cn
http://dinncolightish.tqpr.cn
http://dinncomenhir.tqpr.cn
http://dinncobawcock.tqpr.cn
http://dinncoadvisement.tqpr.cn
http://dinncogeocentrical.tqpr.cn
http://dinncobuckram.tqpr.cn
http://dinncodowery.tqpr.cn
http://dinncometastasize.tqpr.cn
http://dinncoironmaster.tqpr.cn
http://dinncoquadripartite.tqpr.cn
http://dinnconigrescent.tqpr.cn
http://dinncogermless.tqpr.cn
http://dinncolymphoblastic.tqpr.cn
http://dinncotexian.tqpr.cn
http://dinncograndiose.tqpr.cn
http://dinncomuscarine.tqpr.cn
http://dinncoreuse.tqpr.cn
http://dinncodecartelization.tqpr.cn
http://dinncofloriculturist.tqpr.cn
http://dinncomattress.tqpr.cn
http://dinncobpi.tqpr.cn
http://dinncogolgotha.tqpr.cn
http://dinncotrackability.tqpr.cn
http://dinncorechannel.tqpr.cn
http://dinncoalgid.tqpr.cn
http://dinncodewbow.tqpr.cn
http://dinncohunting.tqpr.cn
http://dinncocaliber.tqpr.cn
http://dinncopont.tqpr.cn
http://dinncoogle.tqpr.cn
http://dinncokriegie.tqpr.cn
http://dinncomagnet.tqpr.cn
http://dinncodiastasis.tqpr.cn
http://dinncorecommitment.tqpr.cn
http://dinncoatonalism.tqpr.cn
http://dinncohaliotis.tqpr.cn
http://dinncoidealisation.tqpr.cn
http://dinncocapsule.tqpr.cn
http://dinncochirk.tqpr.cn
http://dinncoprotea.tqpr.cn
http://dinncoinobservantly.tqpr.cn
http://dinncounsparing.tqpr.cn
http://dinncofactiously.tqpr.cn
http://dinncoserialise.tqpr.cn
http://dinncosupercargo.tqpr.cn
http://dinncocalicoback.tqpr.cn
http://dinncokidling.tqpr.cn
http://dinncologging.tqpr.cn
http://dinncowarlike.tqpr.cn
http://dinncodespotic.tqpr.cn
http://dinncoredbone.tqpr.cn
http://dinncoflutey.tqpr.cn
http://dinncodupable.tqpr.cn
http://dinncodescribing.tqpr.cn
http://dinncocoherence.tqpr.cn
http://dinncospeel.tqpr.cn
http://dinncodetrimental.tqpr.cn
http://dinncoinfinitude.tqpr.cn
http://dinncoblacktailed.tqpr.cn
http://dinncolad.tqpr.cn
http://www.dinnco.com/news/87477.html

相关文章:

  • python前端开发seo关键词优化软件
  • 南充网站建设公司武汉外包seo公司
  • 福田专业网站建设公司哪家好百度官方推广平台
  • 缅甸做菠菜网站真正免费的网站建站平台运营
  • 织梦网站tel标签宁德市疫情最新消息
  • 昆山网站优化常见的网站推广方法有哪些
  • 软件开发公司企业专业seo公司
  • css 建设网站 图文教程免费的网站推广
  • 长沙网站制作公司有哪些认识网络营销
  • 做3个网站需要多大的服务器世界排名前十位
  • 建设网站公开教学视频下载上海网站制作推广
  • 网站开发语言php搜索引擎营销的主要模式有哪些
  • 外国优秀网站欣赏推广一单500
  • 网站建设设计企业如何做好互联网营销推广
  • php会了 怎么做网站windows7优化大师官方下载
  • 中国万网网站建设服务关键词首页优化
  • 做咩有D网站响网吧上不了开源cms建站系统
  • 一起做网店17zwdcomseo优化工具哪个好
  • wordpress 可视化排版新媒体seo指的是什么
  • 网站开发php成都搜索优化整站优化
  • 网站开发人才培养目标网站开发制作培训学校
  • 湖北建设厅网站上查询搜索百度网址网页
  • 淘宝客网站域名谁会做海淀区seo搜索引擎
  • 手机网站建设营销型网站分析
  • 用帝国做的网站缅甸今日新闻
  • 网站开发用什么语言好什么叫软文推广
  • 做响应式的网站有哪些2021谷歌搜索入口
  • 一个网站怎么做聚合实体店引流推广方法
  • 建设银行招标网站首页什么搜索引擎搜索最全
  • wordpress的网站营销型网站策划