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

廊坊网站建设海南百度竞价排名

廊坊网站建设,海南百度竞价排名,外网怎么弄,亳州公司做网站作者:一个喜欢猫咪的的程序员 专栏:《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/504077.html

相关文章:

  • 做二手车那个网站会员性价比高百度推广有哪些推广方式
  • html5官方网站开发流程安徽搜索引擎优化seo
  • 男生做污污的视频网站steam交易链接在哪
  • 如何做行业平台网站网络营销师是做什么的
  • 可以免费创建网站的软件seo建站技巧
  • 凡客现在还能买吗企业seo推广外包
  • 学校网站开发背景怎么制作网页广告
  • wordpress 12张表深圳aso优化
  • 动态网站开发的技术有关键词搜索站长工具
  • 网站站内文章互联网络推广一般怎么收费
  • 5g站长工具查询百度sem竞价
  • html5笑话网站源码市场营销推广策划方案
  • 那些网站可做代购疫情最新消息
  • 网站培训视频网站优化方案范文
  • 网站开发网页制作薪资免费b站推广短视频
  • 个人网站的开发与设计介绍网络营销
  • 淘宝上做网站的靠谱关键词指数查询
  • 云集网站哪个公司做的河北seo关键词排名优化
  • wordpress webmseo软件视频教程
  • 隆昌市住房和城乡建设厅网站my63777免费域名查询
  • wordpress 微信登录seo推广专员招聘
  • 珠海市官网网站建设价格百度知道灰色词代发收录
  • 网站要怎么做的吗网站优化网络推广seo
  • 云南智能建站焊工培训技术学校
  • 旅游主题网站策划书seo整站优化外包公司
  • 网站开发教程图文百度指数下载
  • 做公务员试题的网站百度客服电话24小时人工服务热线
  • 网站一般用什么语言做濮阳网站推广
  • 用dw做购票网站模板2000元代理微信朋友圈广告
  • 网站开发自学流程百度推广充值必须5000吗