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

做网站用模板辅导班

做网站用模板,辅导班,网络定制剧,怎么做新网站的推广目录 一、题目二、解法完整代码 一、题目 给定循环单调非递减列表中的一个点,写一个函数向这个列表中插入一个新元素 insertVal ,使这个列表仍然是循环非降序的。 给定的可以是这个列表中任意一个顶点的指针,并不一定是这个列表中最小元素的…

目录

  • 一、题目
  • 二、解法
  • 完整代码


一、题目

给定循环单调非递减列表中的一个点,写一个函数向这个列表中插入一个新元素 insertVal ,使这个列表仍然是循环非降序的。

给定的可以是这个列表中任意一个顶点的指针,并不一定是这个列表中最小元素的指针。

如果有多个满足条件的插入位置,你可以选择任意一个位置插入新的值,插入后整个列表仍然保持有序。

如果列表为空(给定的节点是 null),你需要创建一个循环有序列表并返回这个节点。否则,请返回原先给定的节点。

示例 1:
在这里插入图片描述

输入:head = [3,4,1], insertVal = 2
输出:[3,4,1,2]
解释:在上图中,有一个包含三个元素的循环有序列表,你获得值为 3 的节点的指针,我们需要向表中插入元素 2 。新插入的节点应该在 1 和 3 之间,插入之后,整个列表如上图所示,最后返回节点 3 。

示例 2:
在这里插入图片描述

输入:head = [], insertVal = 1
输出:[1]
解释:列表为空(给定的节点是 null),创建一个循环有序列表并返回这个节点。
示例 3:

输入:head = [1], insertVal = 0
输出:[1,0]

提示:

0 <= Number of Nodes <= 5 * 104
-106 <= Node.val, insertVal <= 106


二、解法

因为是非递减排序,所以直接遍历链表就好了,找到对应的位置插入。
只不过情况有些多,分情况讨论就ok。
如果找到了,就正常插入。
但是有三种特殊情况:
第一种情况,insertval比链表中所有值都大
第二种情况,insertval比链表中所有值都小
第三种情况,链表中所有值一样
又因为是循环链表,一定要有一个条件,判断已经转过一圈了。


完整代码

"""
# Definition for a Node.
class Node:def __init__(self, val=None, next=None):self.val = valself.next = next
"""class Solution:def insert(self, head: 'Optional[Node]', insertVal: int) -> 'Node':# 找到插入位置a = headif a is None:new = Node(insertVal)new.next = newreturn newpre, cur = head.next, headflag = False# 找到最大值while True:# 正常插入if pre.val >= insertVal >= cur.val:cur.next = Node(insertVal, pre)flag = Truebreak# 特殊情况1、2elif cur.val > pre.val:if insertVal <= pre.val or insertVal >= cur.val:cur.next = Node(insertVal, pre)flag = Truebreakcur, pre = cur.next, pre.nextif cur == head:breakif flag:return head# 特殊情况3cur.next = Node(insertVal, pre)return head

http://www.jinmujx.cn/news/77096.html

相关文章:

  • nodejs 网站开发百度云电脑网页版入口
  • 网站开发包含上线吗重庆seo杨洋
  • 路桥网站建设seo网站搭建是什么
  • 网站开发的软件支持写软文是什么意思
  • 自己做的网站怎么才能被收录怎么免费自己做推广
  • 南海大良网站建设公众号推广一个6元
  • 四平专业网站设计网络销售适合什么人做
  • 做国外网站填写价格按人民币写吗南宁seo推广外包
  • 政府门户网站设计模板哪里可以免费推广广告
  • 推广网站排名优化seo教程如何建网址
  • 自己设置网站怎么做外贸接单平台
  • 福田网站制作友情链接推广
  • 广东网站制作设计谷歌浏览器搜索入口
  • 建设部网站拆除资质大连seo网站推广
  • 怎么给钓鱼网站做防红天眼查询个人
  • 视频网站建设seo搜索优化招聘
  • 公司做网站的费用临沂seo推广外包
  • 专门做摩托车的网站运营培训班
  • 建设彩票网站犯法吗潍坊网站建设
  • 电信开放81端口怎样做网站上海网络seo公司
  • 网站建设设计合同书上海最近3天疫情情况
  • 南京公司网站制作教育培训搜索引擎关键词的工具
  • 卧龙区2015网站建设价格淘宝权重查询
  • 做网站哪个公司好 快选宁陵建站宝网站建设推广多少钱
  • 做农业网站关键词优化教程
  • 北京市朝阳区网站开发公司网站优化检测
  • 响应式网站图片代码百度小程序seo
  • 做网站 图片格式亚马逊提升关键词排名的方法
  • 网站与网页区别是什么今日头条指数查询
  • 网站是怎么建立的2345网址导航设为主页