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

2013年建设工程发布网站阿里巴巴做网站

2013年建设工程发布网站,阿里巴巴做网站,邯郸百度公司咋样,seo网站地图前言 关于环形指针与快慢指针是算法题中的常客,如果能掌握将是我们的一大助力! 1.快慢指针 1 移除链表元素​ https://leetcode.cn/problems/remove-linked-list-elements/description/ 1)思路 这道题可以用一个新链表来保存原链表中不…

前言

关于环形指针与快慢指针是算法题中的常客,如果能掌握将是我们的一大助力!

1.快慢指针

在这里插入图片描述

1 移除链表元素​

https://leetcode.cn/problems/remove-linked-list-elements/description/
在这里插入图片描述

1)思路

这道题可以用一个新链表来保存原链表中不是val的值,最后返回新链表的头节点就行。给一个newhead和ptail(作用:用来走链表),给一个purc用来遍历原链表以找到不是val的节点。

2)解析

 typedef struct ListNode slnode;
struct ListNode* removeElements(struct ListNode* head, int val) {slnode*newhead = NULL;slnode*ptail = NULL;slnode* purc=head;if(head==NULL)//给的原链表是空链表时{return NULL;} else//不是空链表{       while(purc){             if(purc->val != val)//当purc中的数据不是val时就''尾插''{if(newhead==NULL)//处理第一个不是val的节点{newhead=ptail=purc;}else//新链表有了第一个节点{ptail->next=purc;ptail=ptail->next;}}purc=purc->next;}if(ptail)//为了断开和原链表的链接ptail->next=NULL;return newhead;}
}

在这里插入图片描述

2 反转链表​

https://leetcode.cn/problems/reverse-linked-list/description/​
在这里插入图片描述

1)思路

反转链表整体来说是比较简单的。创建三个指针就能解决,
n1置为null,n2置为原链表的头指针,n3置为head->next,然后开始循环让n2指向n1,把n1给n2,n2给n3,n3给n3->next,知道n2为空时,n1就是新链表的头节点。

2解析

在这里插入图片描述

 typedef struct ListNode slnode;
struct ListNode* reverseList(struct ListNode* head) {if(head==NULL)//如果处理的是空链表{return NULL;}else//不是空链表{slnode* n1,*n2,*n3;n1=NULL;n2=head;n3=head->next;while(n2){n2->next=n1;n1=n2;n2=n3;if(n3)//如果n3已经走到null,n3就不用走了n3=n2->next;}return n1;}
}

在这里插入图片描述

3 链表的中间结点​(快慢指针)

https://leetcode.cn/problems/middle-of-the-linked-list/description/​
在这里插入图片描述

1)思路

这道题经典的快慢指针,创建一个快指针,和一个慢指针,开始时两个指针都指向头节点,随后慢指针走一步快指针走两步,当快指针走到最后一个节点(链表有奇数个节点)或者为空时(链表有偶数个节点)慢指针就走到了中间节点

2)解析

在这里插入图片描述

typedef struct ListNode slnode;
struct ListNode* middleNode(struct ListNode* head) {slnode* quick=head;slnode* slow=head;if(head==NULL)//处理空链表{return NULL;}else{while(quick && quick->next)//这里quick不能为空,(是为了处理偶数个结点的情况){ slow=slow->next;quick=quick->next->next;//慢指针走一步,快指针走两步}return slow;}
}

在这里插入图片描述

4 合并两个有序链表​

https://leetcode.cn/problems/merge-two-sorted-lists/description/​
在这里插入图片描述

1)思路

这道题与之前的合并有序数组思路大致一致!
合并有序数组大家可以去看一看

2)解析

typedef struct ListNode slnode;
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2)
{if(list1==NULL)//处理空链表{return list2;}else if(list2==NULL){return list1;}else//没有空链表{ slnode* newhead = NULL;slnode* newtail = NULL;while(list1 && list2){if(list1->val > list2->val)//比较,{if(newhead==NULL)//处理第一个节点{newhead=newtail=list2;  list2=list2->next;}else{newtail->next=list2;newtail=newtail->next;list2=list2->next;}}else{if(newhead==NULL)//处理第一个节点{newhead=newtail=list1;list1=list1->next;}else{newtail->next=list1;newtail=newtail->next;list1=list1->next;}}        }//处理有链表提前轮空if(list1)newtail->next=list1;if(list2)newtail->next=list2;return newhead;}
}

在这里插入图片描述

5 链表分割​

https://www.nowcoder.com/practice/0e27e0b064de4eacac178676ef9c9d70
在这里插入图片描述
在这里插入图片描述

1)思路

创建两个新链表,一个放小于x的数据,一个放大于x的数据,最后连接两个链表

2)解析

#include <cstddef>
class Partition {
public:ListNode* partition(ListNode* pHead, int x){// write code hereListNode*lesshead,*lesstail,*bighead,*bigtail;lesshead  = lesstail = (ListNode*)malloc(sizeof(ListNode));//充当哨兵位bighead   = bigtail  = (ListNode*)malloc(sizeof(ListNode));ListNode*purc=pHead;while(purc){            if(purc->val < x)//放到小链表里{lesstail->next=purc;lesstail=lesstail->next;       }else//放到大链表里{bigtail->next=purc;bigtail=bigtail->next;}purc = purc->next;}bigtail->next=NULL;//防止形成环形链表成死循环lesstail->next=bighead->next;//连接大小链表ListNode* ret=lesshead->next;free(lesshead);free(bighead);lesshead=bighead=NULL;return ret;}
};

在这里插入图片描述

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

相关文章:

  • 广州网站建设公司兴田德润可以不素材库图片免费下载
  • 建设绿色食品网站优化型网站的好处
  • 百度做网站要多久昆明小程序开发
  • 湖北省建设工程质量安全监督网站公司网站用wordpress
  • 网站备案 内容做网站用个人还是企业比较好
  • 网站建设行业解决方案wordpress首页js弹窗
  • 南郑县城乡建设局网站乔拓云智能建站免费注册
  • 网页设计素材网站大全开发一个网站需要多少钱
  • 开发一个网站需要哪些技术做网站没有公网
  • 外贸网站制作哪家好rails 网站开发
  • 开福区网站建设论坛做词云的网站
  • 阿里云可以网站备案吗亿网正品
  • 网站空间免费苏州市建设局招标网站首页
  • 中国五大网站建设公司做百度移动端网站优
  • 什么浏览器可以看违规网站wordpress主页显示全文
  • 规划电子商务网站流程一般通过什么查看天气预报
  • 济南工装定制公司石家庄百度推广优化排名
  • 小公司让我用织梦做网站专业seo优化公司
  • 沈阳网站建设 熊掌号网络规划设计师和系统规划与管理师哪个容易
  • 天津 网站设计公司什么是网络建设
  • 公司网站建设费用入什么费用wordpress第三方登录组件
  • 网站建设礼品水头做网站
  • 网站建设熊掌号里属于什么领域微网站 app 区别
  • 电商网站建设培训做兼职看什么网站好
  • 做破解软件网站赚广告费好动词做的网站能行吗
  • 保定百度网站建设黄南网站建设
  • 各网站特点wordpress开启静态网页
  • 梅林网站建设公司wordpress数据库ip
  • 做网站支付系统无锡网站制作优化推广
  • 常州外贸集团 网站建设视频网站开发 价格