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

南山网站建设 信科网络地方门户网站源码下载

南山网站建设 信科网络,地方门户网站源码下载,网站开发工程师社交,公章电子版在线制作文章目录 🍀题目🍀解法一🍀解法二🍀哈希表 🍀题目 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每…

文章目录

  • 🍀题目
  • 🍀解法一
  • 🍀解法二
  • 🍀哈希表

🍀题目

请添加图片描述

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

在这里插入图片描述


🍀解法一

暴力解法,最先想到的方法
但是在运行的时候出现了一个问题

 for i in len(nums):for j in range(i+1, len(nums)):if nums[i]+nums[j]==target:return [i,j]

但是报错了(还是本人基本语法掌握不好)
在这里插入图片描述
经查阅后

错误消息"TypeError: ‘int’ object is not iterable"通常在Python中出现,当您尝试像遍历(循环)可迭代对象一样遍历整数(int)值时,比如列表、元组或字符串等时会出现此错误。在Python中,您只能遍历支持迭代的对象,如序列和集合。总的来看列表、字典、集合、元组、字符串可迭代;整数、浮点数、布尔、NoneType不可迭代

修改后的代码如下

n = len(nums)for i in range(n):for j in range(i+1, n):if nums[i]+nums[j]==target:return [i,j]

在这里插入图片描述

补充:range(n) 创建的对象是一个类似于序列的可迭代对象,但它实际上并不存储整个范围内的所有值,而是根据需要生成这些值,从而节省内存空间。这种懒加载(lazy loading)的方式使得 range 在处理大范围的整数时非常高效


🍀解法二

思路及算法

注意到方法一的时间复杂度较高的原因是寻找 target - x 的时间复杂度过高。因此,我们需要一种更优秀的方法,能够快速寻找数组中是否存在目标元素。如果存在,我们需要找出它的索引。

使用哈希表,可以将寻找 target - x 的时间复杂度降低到从 O(N)O(N)O(N) 降低到 O(1)O(1)O(1)。

这样我们创建一个哈希表,对于每一个 x,我们首先查询哈希表中是否存在 target - x,然后将 x 插入到哈希表中,即可保证不会让 x 和自己匹配。

class Solution:def twoSum(self, nums: List[int], target: int) -> List[int]:hashtable = dict()for i, num in enumerate(nums):if target - num in hashtable:return [hashtable[target - num], i]hashtable[nums[i]] = ireturn []

官方给出的答案里,有些函数和语句可能不太了解,这里我说明一下

  • dict()是创建一个空字典

  • enumerate() 是一个内置函数,用于在迭代过程中同时获取索引和元素值,通常用于循环遍历列表、元组、字符串等可迭代对象时。其基本语法如下:

  • hashtable[nums[i]] = i 的作用是将列表中的元素作为键,将其索引作为值,存储到一个哈希表(字典)中。这个哈希表可以用来快速查找特定元素在列表中的索引,因为字典的键是唯一的,通过元素值可以直接定位到其索引。

    iterable 是要枚举的可迭代对象,如列表、元组、字符串等。
    start 是可选参数,表示索引起始值,默认为0,但你可以指定一个不同的起始值。
    enumerate() 返回一个迭代器,每次迭代都产生一个元组,包含两个值:索引和元素值。索引从指定的起始值开始递增。


🍀哈希表

哈希表(Hash Table),也被称为散列表,是一种常见的数据结构,用于高效地存储和检索键值对(key-value pairs)。哈希表的核心思想是通过将键(key)映射到一个确定的位置(索引)来实现快速的数据访问。这个映射函数被称为哈希函数(hash function)。

以下是哈希表的主要特点和工作原理:

  • 快速查找: 哈希表的主要优势在于它可以在平均情况下(取决于哈希函数的质量和哈希表的实现方式)提供常数时间复杂度的查找操作,即O(1)时间复杂度。

  • 哈希函数: 哈希表的关键部分是哈希函数,它将键映射到哈希表中的一个位置。好的哈希函数应该尽可能均匀地分布键,以减少冲突(多个键映射到同一位置)的发生。冲突是哈希表需要解决的主要问题之一。

  • 冲突解决: 当两个不同的键经过哈希函数映射到同一位置时,就发生了冲突。哈希表有多种方法来解决冲突,包括链地址法(Chaining)、开放寻址法(Open Addressing)等。每种方法都有自己的优点和适用场景。

  • 动态扩展: 哈希表通常会动态扩展,以处理更多的键值对。当表格装填因键值对的添加而变得过高时,哈希表会重新调整大小,以保持其性能。

  • 无序性: 哈希表是无序的数据结构,键值对的顺序不一定与它们被添加到哈希表的顺序相同。

哈希表在计算机科学中有广泛的应用,常见用途包括实现字典、集合、缓存等数据结构,以及在数据库索引、哈希表查找等领域中的优化。哈希表的性能取决于哈希函数的质量和解决冲突的方法,因此在设计和使用哈希表时,需要注意选择合适的哈希函数和解决冲突的策略,以确保其高效性和稳定性。


挑战与创造都是很痛苦的,但是很充实。

http://www.yayakq.cn/news/525306/

相关文章:

  • 网络设备互联课设建设企业网站制作网页的第一步是什么
  • 网站建设报告论文网站建设要学哪些软件有哪些方面
  • 如何做旅游网站视频结交网站怎么做
  • 百度竞价做网站建设网站建设脱颖而出
  • 西安网站建设加q479185700做哪些网站比较赚钱方法有哪些
  • 网站买空间的价格设计之家素材
  • 苏州网站建设营销推广做户型图的网站
  • 怎么才能有自己的网站网站如何做视频
  • 徐州app制作怎么查看一个网站页面的seo优化情况
  • 公司网站在国外打开很慢使用cdn好还是国外租用服务器好商城网站建设适合于哪类企业
  • 建设通网站不良信用信息撤销开发网站需要问什么
  • 网站专题设计软件网站开发 怎样做费用结算
  • 哪个公司做网站好做兼职上什么网站找
  • 东莞市建设厅官方网站网站做链接
  • 开网站的是啥公司ps个人主页设计模板
  • 郑州七彩网站建设公司做网站和SSH
  • 招远网站开发做图网站
  • 网站降权表现程序员做项目网站
  • 多种网站建设专业建设研讨会
  • 中国市场营销网seo长沙
  • 有没有免费装修设计的网站做网站建设与推广企业
  • 网站域名空间到期自己怎么续费wordpress图片小程序
  • 龙口网站建设无本钱创业22种方法
  • 做网站的用什么主机好如何做新闻自动采集网站
  • 东莞手机手机端网站建设学校网站建设与管理办法
  • 成都著名网站神起网络游戏推广平台
  • 大连企业做网站公司排名上海网站建设公司sky
  • 青岛网站建设 推荐青岛博采网络wordpress 视频显示图片
  • 精品课程网站设计最新房产信息
  • 订货网站怎么做广州专业网站开发