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

廊坊网站建设sem竞价培训班

廊坊网站建设,sem竞价培训班,网站建设程序编制,网站推广销售腾讯会员被告怎么办作者:一个喜欢猫咪的的程序员 专栏:《Leetcode》 喜欢的话:世间因为少年的挺身而出,而更加瑰丽。 ——《人民日报》 目录 206.反转链表 203.移除链表元素 206.反转链表 力扣https://leetcode…

作者:一个喜欢猫咪的的程序员

专栏:《Leetcode》

喜欢的话:世间因为少年的挺身而出,而更加瑰丽。                                  ——《人民日报》


目录

206.反转链表 

203.移除链表元素


206.反转链表 

力扣https://leetcode.cn/problems/reverse-linked-list/题目描述:

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。


 示例:

示例 1:


输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
 

 示例 2:

输入:head = [1,2]
输出:[2,1]
 

示例 3:

输入:head = []
输出:[]


思路:

思路一:头插法

设一个变量cur遍历整个链表,并且创建一个新的链表rhead我们将cur一个一个头插进去,但这样会找不到cur的下一个位置,因此我们提前设一个变量next来找cur的下一个位置。

时间复杂度:O(N)                                                            空间复杂度:O(1) 

思路二:递归法

利用递归找到最后一个位置,让他倒置

需要注意的是 n1​ 的下一个节点必须指向空。如果忽略了这一点,链表中可能会产生环。

时间复杂度:O(N)                                                            空间复杂度:O(N) 


代码实现:

思路一:头插法

struct ListNode* reverseList(struct ListNode* head) {struct ListNode* cur = head;struct ListNode* rhead = NULL;while (cur){struct ListNode* next = cur->next;cur->next = rhead;rhead = cur;cur = next;}return rhead;
}

思路二:

struct ListNode* reverseList(struct ListNode* head){if (head == NULL || head->next == NULL) {return head;}struct ListNode*newhead=reverseList(head->next);head->next->next=head;head->next=NULL;return newhead;
}

203.移除链表元素

力扣https://leetcode.cn/problems/remove-linked-list-elements/题目描述:

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。


示例:

示例 1:
输入: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
输出:[]


思路:

思路一:尾插迭代法

利用创建一个新的链表newhead,利用cur如果cur->val=val时,让这个cur下来到newhead,否则删掉。

 时间复杂度:O(N)                                                    空间复杂度:O(1)


思路二:递归法

对于给定的链表,首先对除了头节点 head以外的节点进行删除操作,然后判断 head 的节点值是否等于给定的 va。如果 head 的节点值等于va,则head 需要被删除,因此删除操作后的头节点为 head,next如果head的节点值不等于 val,则 head 保留,因此删除操作后的头节点还是 head。上述过程是一个递归的过程。

递归的终止条件是 head 为空,此时直接返回 head。当 head 不为空时,递归地进行删除操作,然后判断 head 的节点值是否等于 val 并决定是否要删除head。

作者:LeetCode-Solution
来源:力扣(LeetCode)

时间复杂度:O(N)                                                    空间复杂度:O(N)


代码实现:

思路一:尾插迭代法

struct ListNode* removeElements(struct ListNode* head, int val) {struct ListNode* cur = head;struct ListNode* newhead, * tail;newhead = tail = NULL;if(head==NULL)
{return NULL;
}while (cur){if (cur->val != val){if (tail==NULL){tail = newhead = cur;}else{tail->next = cur;tail = cur;}cur = cur->next;}else{struct ListNode* next = cur->next;free(cur);cur = next;}}if(tail!=NULL)tail->next = NULL;return newhead;
}

思路二:递归法:

struct ListNode* removeElements(struct ListNode* head, int val) {if (head == NULL) {return head;}head->next = removeElements(head->next, val);return head->val == val ? head->next : head;
}

http://www.dtcms.com/wzjs/395150.html

相关文章:

  • 做网站公司叫什么杭州网站建设
  • 网站做接口排线方法seo上海推广公司
  • asp.net怎么做登录网站希爱力双效片骗局
  • 广州网站建设如何做国内网络销售平台有哪些
  • 宁波seo网络推广选哪家青岛网站制作seo
  • 建网站英语排名优化外包公司
  • 珠海哪里做网站的国外b站浏览器
  • 如何给网站绑定域名河南今日头条新闻
  • 用代码怎么做网站18款禁用软件黄app免费
  • 做三合一网站的好处幽默软文广告经典案例
  • 福州市建设局网站 动态优化设计七年级下册语文答案
  • 网站制作有哪些技术百度一下下载安装
  • 个人做医疗类网站违法?网络营销课程学什么
  • 网站建设xm37怎么找拉新推广平台
  • 做签证网站产品宣传推广方式有哪些
  • 中国住房城乡建设部官方网站seo资料站
  • 亚马逊云服务 网站建设网络营销平台都有哪些
  • 提升学历的机构seo查询 站长之家
  • 上海网站设计费用论坛企业推广
  • 做商铺最好的网站外贸网站建设优化
  • wordpress 自动webp百度seo优化分析
  • 东莞建设小学网站网站推广建设
  • html做网站需要服务器吗营销软件代理推广
  • 邢台地区网站建设有创意的网络广告案例
  • 餐饮美食网站模板源码河北seo推广公司
  • 大庆做网站比较好的公司企业网站建设的重要性
  • 企业网页模板图片seo具体是什么
  • 专门做面条菜谱的网站整合营销策略有哪些
  • 吉林省建设厅证件查询网站百度邮箱登录入口
  • 保姆给老人做爰神马网站seo教程搜索引擎优化入门与进阶