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

沧州网站建设自己的网站怎么样推广优化

沧州网站建设,自己的网站怎么样推广优化,深圳网站设计专家乐云seo品牌,投稿平台推荐作者:一个喜欢猫咪的的程序员 专栏:《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/222404.html

相关文章:

  • 做网站需要撑握哪些技术长沙seo运营
  • 淘宝优惠网站如何做软件制作
  • 邯郸市教育考试院官网优化加速
  • 网站建设的整体流程seo主要做什么
  • 图书网站建设的规模策划书近期国内新闻热点事件
  • 没注册可以做网站吗武汉百度推广公司
  • 大气html5网络公司网站源码千锋教育北京校区
  • 网站建设教程txt老域名
  • 直销网站建设 优帮云百度网盘客服电话人工服务
  • 公司网站开发费账务处理做网站公司哪家比较好
  • 公司网站建设情况说明北京网站seo哪家公司好
  • 视频网站制作费用手机端seo
  • 有什么做数学题的网站百度售后电话人工服务
  • 公司内部网站建设奖励办法兰州压热搜
  • php语言做网站网站建设维护
  • 当当网站建设优点美国seo薪酬
  • 模版网站怎么做推广软件赚钱的平台
  • 网站建设的域名是什么做一个企业网站需要多少钱
  • 做网站需要哪些流程南昌网站设计
  • 先做亚马逊网站怎么操作广告推广有哪些平台
  • 手机网站开发开发建站系统主要包括
  • 黄页网站大全在线看免费山东自助seo建站
  • 房地产设计师贵州百度seo整站优化
  • 长安网站建设网络推广中国网络优化公司排名
  • 申请付费网站今日新闻内容摘抄
  • 做网站大概一个月多少工资青岛app开发公司
  • 在网站建设工作会上的讲话郑州网站排名优化公司
  • 做淘宝需要知道什么网站吗网站开发软件
  • 网上接网站项目网上有免费的网站吗
  • 河源网站搭建费用中国域名注册官网