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

太原做淘宝网站的郑州seo管理

太原做淘宝网站的,郑州seo管理,做网站被诈骗,制作视频的软件手机Python算法题集_环形链表 题234:环形链表1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【集合检索】2) 改进版一【字典检测】3) 改进版二【双指针】 4. 最优算法 本文为Python算法题集之一的代码示例 题234:环形链表 …

 Python算法题集_环形链表

  • 题234:环形链表
  • 1. 示例说明
  • 2. 题目解析
    • - 题意分解
    • - 优化思路
    • - 测量工具
  • 3. 代码展开
    • 1) 标准求解【集合检索】
    • 2) 改进版一【字典检测】
    • 3) 改进版二【双指针】
  • 4. 最优算法

本文为Python算法题集之一的代码示例

题234:环形链表

1. 示例说明

  • 给你一个链表的头节点 head ,判断链表中是否有环。

    如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

    如果链表中存在环 ,则返回 true 。 否则,返回 false

    示例 1:

    img

  输入:head = [3,2,0,-4], pos = 1
输出:true解释:链表中有一个环,其尾部连接到第二个节点。

示例 2:

img

输入:head = [1,2], pos = 0
输出:true
解释:链表中有一个环,其尾部连接到第一个节点。

示例 3:

img

输入:head = [1], pos = -1
输出:false
解释:链表中没有环。

提示:

  • 链表中节点的数目范围是 [0, 104]
  • -105 <= Node.val <= 105
  • pos-1 或者链表中的一个 有效索引

**进阶:**你能用 O(1)(即,常量)内存解决此问题吗?


2. 题目解析

- 题意分解

  1. 本题为链表的值查重
  2. 本题的主要计算有2处,1是链表遍历,2是值比较
  3. 基本的解法是单层循环,必须读取链表数据后进行检测,所以基本的时间算法复杂度为O(n)

- 优化思路

  1. 通常优化:减少循环层次

  2. 通常优化:增加分支,减少计算集

  3. 通常优化:采用内置算法来提升计算速度

  4. 分析题目特点,分析最优解

    1. 链表需要遍历中进行值检查,为提高检索速度,可以采用哈希检索,采用setdict等数据结构

    2. 空间复杂度为O(1)的算法,一般是需要用到快慢双指针


- 测量工具

  • 本地化测试说明:LeetCode网站测试运行时数据波动很大,因此需要本地化测试解决这个问题
  • CheckFuncPerf(本地化函数用时和内存占用测试模块)已上传到CSDN,地址:Python算法题集_检测函数用时和内存占用的模块
  • 本题很难超时,本地化超时测试用例自己生成,详见【最优算法章节】

3. 代码展开

1) 标准求解【集合检索】

采用集合set进行值检索

性能优良,超过88在这里插入图片描述

import CheckFuncPerf as cfpdef hasCycle_base(head):set_checked = set()  while head: if head in set_checked:return Trueset_checked.add(head)  head = head.next  return Falseresult = cfp.getTimeMemoryStr(hasCycle_base, head1)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 运行结果
函数 hasCycle_base 的运行时间为 27.01 ms;内存使用量为 996.00 KB 执行结果 = True

2) 改进版一【字典检测】

采用字典dict进行值检索,由于字典分配内存远大于集合,因此哈希检索的效率要低一些

马马虎虎,超过64%在这里插入图片描述

import CheckFuncPerf as cfpdef hasCycle_ext1(head):dict_checked = {} while head:  dict_checked[head] = dict_checked.get(head, 0)if dict_checked[head] == 1:return Truedict_checked[head] = 1head = head.next return Falseresult = cfp.getTimeMemoryStr(hasCycle_ext1, head1)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 运行结果
函数 hasCycle_ext1 的运行时间为 58.00 ms;内存使用量为 128.00 KB 执行结果 = True

3) 改进版二【双指针】

没有很多内存分配的事,空间复杂度好的算法,时间复杂度也很好
表现优异,超越95%在这里插入图片描述

import CheckFuncPerf as cfpdef hasCycle_ext2(head):slownode , fastnode = head, headwhile fastnode and fastnode.next:slownode = slownode.nextfastnode = fastnode.next.nextif slownode == fastnode:breakif fastnode and fastnode.next:while head != slownode:head = head.nextslownode = slownode.nextreturn Trueelse:return Falseresult = cfp.getTimeMemoryStr(hasCycle_ext2, head1)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 运行结果
函数 hasCycle_ext2 的运行时间为 30.01 ms;内存使用量为 0.00 KB 执行结果 = True

4. 最优算法

根据本地日志分析,最优算法为第1种hasCycle_base

# 超时测试
nums = [x for x in range(200000)]
def generateOneLinkedList(data):head = ListNode(-100)iPos = 0current_node = headfor num in data:iPos += 1if iPos == 190000:CycleNode = new_nodenew_node = ListNode(num)current_node.next = new_nodecurrent_node = new_nodenew_node.next = CycleNodereturn head.next, new_node
head1, tail1 = generateOneLinkedList(nums)result = cfp.getTimeMemoryStr(hasCycle_base, head1)
print(result['msg'], '执行结果 = {}'.format(result['result']))# 算法本地速度实测比较
函数 hasCycle_base 的运行时间为 27.01 ms;内存使用量为 996.00 KB 执行结果 = True
函数 hasCycle_ext1 的运行时间为 58.00 ms;内存使用量为 128.00 KB 执行结果 = True
函数 hasCycle_ext2 的运行时间为 30.01 ms;内存使用量为 0.00 KB 执行结果 = True

一日练,一日功,一日不练十日空

may the odds be ever in your favor ~

http://www.mmbaike.com/news/91661.html

相关文章:

  • 郑州北环网站建设培训如何查询网站收录情况
  • 做网站要有自己服务器吗上海专业的seo推广咨询电话
  • 做的网站如何改标题百度数字人内部运营心法曝光
  • 培训网站源码wordpress企业员工培训课程有哪些
  • 直播平台开发方案宁波优化推广选哪家
  • 做系统吧收藏的网站做没了北京网站推广排名
  • 做公益网站又什么要求搜索引擎排名优化技术
  • 东莞网站制作建设收费列表网推广效果怎么样
  • 网站建设实验总结建站优化
  • html网站的规划与建设优化公司排名
  • php站点搭建优化技术
  • 上海建设工程招投标网站全网引流推广 价格
  • 网站广告用ps如何做电商运营培训哪个机构好
  • 淘宝做收藏的网站天津短视频seo
  • 外贸出口网站建设快手seo软件下载
  • 织梦做的网站怎么添加关键词2022近期重大新闻事件10条
  • 建设部网站查资质6不能搜的超级恶心的关键词
  • 付费阅读小说网站开发建设源码武汉百度推广开户
  • 怎么做秒赞网站2022年最近十大新闻
  • 用手机做网站视频宁波seo关键词优化教程
  • 北京做网站的外包公司百合seo培训
  • 响应式网站价格p2p万能搜索引擎
  • 石家庄做网站汉狮网络app推广方案范例
  • 交互设计师网站qq引流推广软件哪个好
  • wordpress输入域名跳转登录长沙关键词优化服务
  • 哪个网站可以免费制作h5seo搜索引擎优化培训班
  • 家教网站开发今日国内新闻热点
  • 虹口网站建设吸引人的软文
  • 网站图片优化怎么做长沙网站关键词推广
  • 网站建设需要软件外贸推广网站