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

2022贵州疫情最新消息今天又封了seo流程

2022贵州疫情最新消息今天又封了,seo流程,苏州市住房建设局网站首页,那些网站平台可以做3d建模1 删除链表中等于给定值 val 的所有节点 删除链表中等于给定值 val 的所有节点 给你一个链表的头节点head和一个整数val,请你删除链表中所有满足Node.valval的节点,并返回新的头节点 输入:head [1,2,6,3,4,5,6], val 6 输出:[…

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

删除链表中等于给定值 val 的所有节点
给你一个链表的头节点head和一个整数val,请你删除链表中所有满足Node.val==val的节点,并返回新的头节点
在这里插入图片描述
输入:head = [1,2,6,3,4,5,6], val = 6
输出:[1,2,3,4,5]
示例 2:
输入:head = [ ], val = 1
输出:[ ]
示例 3:
输入:head = [7,7,7,7], val = 7
输出:[ ]
思路如下
在这里插入图片描述
见详细代码

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* removeElements(struct ListNode* head, int val){struct ListNode*prev=NULL;struct ListNode*cur=head;while(cur){if(cur->val==val){if(cur==head){head=cur->next;cur=head;}// head=cur->next;// cur=head;else{prev->next=cur->next;cur=prev->next;}}else{prev=cur;cur=cur->next;}// else// {//     prev->next=cur->next;//     cur=prev->next;// }}return head;
}

上述注释掉的代码是我在写的时候犯的错误,大家也可以试着自己写写看会不会和我犯同样的错误
如果有其他思路可以随意发表意见!

2 给定一个带有头结点 head 的非空单链表,返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点

给定一个带有头结点 head 的非空单链表,返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点
给你单链表的头结点head ,请你找出并返回链表的中间结点
如果有两个中间结点,则返回第二个中间结点
在这里插入图片描述
输入:head = [1,2,3,4,5]
输出:[3,4,5]
解释:链表只有一个中间结点,值为3
在这里插入图片描述
输入:head = [1,2,3,4,5,6]
输出:[4,5,6]
解释:该链表有两个中间结点,值分别为3和4,返回第二个结点
思路
大部分人呢第一个想到的就是先去遍历一遍链表计算出链表的长度—然后再次遍历一遍链表找到链表的的中间结点
但是如果是在面试的时候面试官让你只能遍历一次那你应该怎么处理呢?
这里运用的是快慢指针的相对速度
这时候我们可以考虑用快慢指针来作答
在这里插入图片描述
fast走两步,slow走一步,刚好天时地利人和走到了中间结点的位置
详细代码

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* middleNode(struct ListNode* head){struct ListNode*slow=head;struct ListNode*fast=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;}return slow;
}

3 输入一个链表,输出该链表中倒数第k个结点

输入一个链表,输出该链表中倒数第k个结点
描述
输入一个链表,输出该链表中倒数第k个结点
示例1
输入:1,{1,2,3,4,5}
返回值:{5}
在这里插入图片描述
思路一致
这里运用的快慢指针的相对距离
解法一

struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) {struct ListNode* cur=pListHead;int count=0;//建立一个计数器if(pListHead==NULL)//如果链表为空,则返回空指针{return NULL;}while(cur)//循环遍历链表,求出链表的长度{cur=cur->next;count++;}if(k>0&&k<=count)//对k值的合理性进行判断{int pos=count-k;//求出循环的次数while(pos){pListHead=pListHead->next;pos--;}return pListHead;//找到就返回目标结点}return NULL;
}

解法二

//计数法 时间复杂度:0(n) 空间:O(1)
struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) 
{// write code hereif(pListHead == NULL || pListHead->next == NULL)//若链表没有结点或只有一个结点时返回(第二条件不必须){return pListHead;}int nodenums = 0;//记录总结点数(第一次遍历)int returnnums = 0;//第二次遍历(每经过一次结点,前置+1)用于排查K结点struct ListNode* cur = pListHead;while(cur != NULL)//计数遍历{nodenums++;cur = cur->next;}if(k>nodenums)//如果k>总结点数,则代表不存在这一结点,返回空{return NULL;}struct ListNode* pwe = pListHead;while(pwe != NULL)//第二次遍历,寻找倒数K点{++returnnums;//每经过一个结点就+1if(nodenums-returnnums < k)//如果结点总数减去当前结点数小于K,那么这个结点就是倒数K结点;{break;}pwe = pwe->next;}return pwe;
}

4 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的

将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
在这里插入图片描述
输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]
示例 2:
输入:l1 = [ ], l2 = [ ]
输出:[ ]
示例 3:
输入:l1 = [ ], l2 = [0]
输出:[0]
思路
在这里插入图片描述
在这里插入图片描述
本质上是结构体指针的地址和成员变量next的相互赋值,这里也涉及到了链表的尾插,直接套用就可以了,前提是掌握好了链表的增删查改基本逻辑
代码演示

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){if(list1==NULL){return list2;}else if(list2==NULL){return list1;}//定义一个head和tail//head和tail最初都置为NULL//tail=tail->next//尾部插入struct ListNode*head=NULL;struct ListNode*tail=NULL;while(list1&&list2){//取小的尾部插入if(list1->val<list2->val){if(tail==NULL){head=tail=list1;//tail=tail->next;}else{tail->next=list1;tail=tail->next;}list1=list1->next;   }else{if(tail==NULL){head=tail=list2;}else{tail->next=list2;tail=tail->next;}list2=list2->next; }}if(list1){tail->next=list1;}else if(list2){tail->next=list2;}return head;
}
http://www.yidumall.com/news/74450.html

相关文章:

  • 营销型网站的优势深圳推广公司哪家正规
  • 1核1g服务器做网站网站推广主要是做什么
  • 域名到期换个公司做网站桂平seo关键词优化
  • 做网站公司共有几处密码做网站用哪个软件
  • 加快实施创新驱动发展战略沈阳网络seo公司
  • 网站代更新windows优化
  • php做网站要多久建网站的流程
  • 崇州网站建设公司域名注册步骤
  • 做时时彩网站平台集客营销软件官方网站
  • Wordpress建站安装教程图解网站外链查询
  • python做网站模板会计培训
  • 前端网站开发毕设类型做网站用什么软件好
  • icp备案 网站备案泉州关键词优化报价
  • 新疆分享是官方网站吗?谷歌搜索网页版入口
  • 做网站改变图片位置中国新闻网最新消息
  • 网站怎么做英语和中文的口碑营销的优势
  • 资深的网站推广武汉官网优化公司
  • 企业建筑网站全网搜索引擎
  • 西安响应式网站建设公司企业推广策划书
  • 上海网站建设公司选哪家好网站推广的主要方式
  • 做外贸做的很好的网站学电脑培训班
  • 深圳做网站补贴计算机培训班培训费用
  • 电影网站权重怎么做网络营销毕业论文8000字
  • 网站的域名可以修改吗大数据精准获客软件
  • 中国建设银行掌上银行官方网站做seo需要哪些知识
  • 如何查看网站建设时间南宁网站seo大概多少钱
  • 网站开发哪个好东莞今天新增加的情况
  • 撤销网站备案百度网盘官方下载
  • 淄博张店网站排名优化联赛积分榜排名
  • 美国网站空间下载班级优化大师app