首页 > 编程语言 >DSA 与 JS:用 JavaScript 解释大 O 表示法

DSA 与 JS:用 JavaScript 解释大 O 表示法

时间:2024-09-20 19:35:18浏览次数:1  
标签:10 元素 示例 JavaScript JS let 数组 输入 DSA

废话不多说,我们直接进入正题吧。什么是大 o 表示法以及它的用途是什么?明确的答案是 big o 表示法是一种描述算法性能如何随着输入大小的增长而变化的方法。它可以帮助您了解处理越来越大的数据量时代码的速度有多快或多慢。简单来说,big o 会告诉您最坏的情况,即随着输入变大,代码将花费多长时间或需要多少空间。有不同类型或种类的 big o 符号来描述算法随着输入大小的增长而表现如何。这些不同的符号代表不同的效率或性能水平。每种类型都会告诉您算法根据输入大小需要多少时间或空间。 一些常见的 o 符号 o(1) – 恒定时间当一个操作需要相同的时间来完成时,无论输入的大小如何,它都被视为o(1)。这意味着无论您处理的数据有多大或多小,执行操作的时间都是恒定的,并且不会随着输入的增长而增加。立即学习“Java免费学习笔记(深入)”;示例 1:访问数组元素let numbers = [10, 20, 30, 40, 50];// if you want to access an element at a specific index, like:let num = numbers[2]; // this will give you 30登录后复制无论数组有多大,此操作将始终花费相同的时间。无论数组有 5 个元素还是 500 万个元素,直接访问 numbers[2] 的时间总是o(1),因为您只是使用其索引获取一个值。示例 2:赋值let a = 10;登录后复制示例 3:检查数字是否为偶数function iseven(number) { return number % 2 === 0;}登录后复制无论数字有多大,该函数的运行时间都是相同的。所以,这也是 o(1). o(n) – 线性时间在o(n)中,完成操作所需的时间随着输入的大小直接增加。如果输入加倍,执行操作所需的时间也会加倍。发生这种情况是因为算法需要处理输入中的每一项逐一。示例 1:循环数组假设您有一个数组,并且想要打印其中的每个元素。所需的时间取决于数组中有多少元素。这是一个简单的例子:let numbers = [10, 20, 30, 40, 50];for (let i = 0; i <p>在此示例中:</p>登录后复制如果数组有 5 个元素,则循环将运行 5 次。如果数组有 100 个元素,则循环将运行 100 次。如果数组有 n 个元素,则循环将运行 n 次。示例 2:在数组中搜索值假设你想查找数组中是否存在特定值:function findvalue(arr, target) { for (let i = 0; i <p>在此示例中:</p>登录后复制如果数组有 10 个元素,循环可能会运行最多 10 次来查找值。如果数组有 1,000 个元素,则循环可能最多运行 1,000 次。对于 n 个元素,在最坏的情况下循环可能会运行 n 次。因此,数组越大,检查每个元素所需的时间就越长,使其o(n)。 o(n2) – 二次时间o(n2) 表示完成算法所需的时间随着输入大小的增加呈指数级增加。具体来说,如果输入大小加倍,则所需时间会增加四倍(因为 22 = 4)。如果输入增加三倍,时间就会增加 九倍(因为 32 = 9)。当您有嵌套循环时,通常会发生这种情况,其中一个循环迭代输入,然后在该循??环内,另一个循环也迭代相同的输入。数组上的嵌套循环: 假设您有一个数组,并且您想要将每个元素与数组中的每个其他元素进行比较。这是一个例子:let numbers = [10, 20, 30, 40, 50];for (let i = 0; i <p>这是发生的事情:</p>登录后复制外循环运行n次(其中n是数组的长度)。对于外循环的每次迭代,内循环也运行n次。因此,对于数组中的每个项目,您都会再次循环遍历每个项目。如果数组有 5 个元素,则 5 次外循环迭代中的每一次内循环都会运行 5 次,使其总共运行 25 次 (5 × 5 = 25)。这使得时间复杂度 o(n2),因为对于 n 个元素,您正在执行 n × n 操作。o(n2) 总结: 当您有嵌套循环时,就会发生 o(n2),其中两个循环都迭代相同的输入。所花费的时间随着输入的大小呈二次方增长。与 o(n) 和 o(log n) 相比,它的速度较慢,因为随着输入大小的增加,操作数量增长得更快。二次时间在冒泡排序等算法或需要比较数据集中每对项目的问题中很常见。 o(log n) – 对数时间我认为这个需要更多的关注和仔细来掌握这个概念。在 o(log n) 中,时间 随着输入大小的增大而增加,但与其他时间复杂度(如 o( n) 或 o(n2).这里是关键思想: 在 o(log n) 算法中,每一步都会显着减少问题大小(通常减少一半),这意味着随着输入变大,所需的额外步骤数量不会增加太多。事实上,它对数增长,意味着增长非常缓慢。 比较 o(n) 和 o(log n) o(n) – 线性时间:如果您有 10 件商品,则可能需要 10 个步骤。如果您有 100 个项目,则需要 100 个步骤。如果您有 1,000 个项目,则需要 1,000 个步骤。这里,时间随着输入大小直接增长。 o(log n) – 对数时间:如果您有 10 个项目,则可能需要大约 4 个步骤(因为 log 2(10) ≈ 4)。如果您有 100 个项目,则只需要大约 7 个步骤(因为 log 2(100) ≈ 7)。如果您有 1,000 个项目,则只需要大约 10 个步骤(因为 log2(1,000) ≈ 10)。尽管输入增长很多(从 10 到 1,000),步数(“时间”)仅略有增加(从 4 步到 10 步)。 二分查找o(log n) 的一个经典示例是 二分搜索。假设您有一个已排序的数组,并且您想要查找数组中是否存在目标数字。您可以在每一步将搜索空间减半,而不是一一检查每个数字(这将是 o(n))。这是二分搜索的示例:function binarySearch(arr, target) { let left = 0; let right = arr.length - 1; while (left <h3> 运作原理:</h3>登录后复制首先将数组的中间元素与目标进行比较。如果中间元素是目标,则完成。如果中间元素小于目标,则丢弃数组的左半部分并仅在右半部分搜索。如果中间元素较大,则丢弃右半部分并在左半部分搜索。每次,您都会将数组切成两半。 最后的话大 o 表示法 用于描述算法的时间或空间复杂度如何随着输入大小的增长而变化。它为我们提供了一种讨论算法效率的方法,特别是当输入变大时。 big o 专注于最坏情况,帮助我们了解算法性能的上限。 以上就是DSA 与 JS:用 JavaScript 解释大 O 表示法的详细内容,更多请关注我的其它相关文章!

标签:10,元素,示例,JavaScript,JS,let,数组,输入,DSA
From: https://www.cnblogs.com/aow054/p/18423160

相关文章

  • billboardjs elease:新的区域步长图表!
    新的v3.13版本今天发布了!此版本包含4个新功能、2个错误修复和工具改进。详细发布信息请查看发行说明:https://github.com/naver/billboard.js/releases/tag/3.13.0什么是新的?面积步长范围图范围类型对于从基线值可视化“范围值”很有用。从这个版本开始,将为变体提......
  • 使用HTML+JS实现国庆节倒计时网页实例代码
    马上就是每年10月1日的国庆节了,为了增加节日氛围,许多网站会设置倒计时,以提醒人们国庆节的临近。本文站长工具网将介绍如何使用HTML和JavaScript创建一个简单的国庆节倒计时网页,并附上完整的实例代码供大家参考。1.网页设计基础在开始编写代码之前,我们需要了解一些基本的网......
  • python模块之json
    json模块(1)python中的json格式是轻量级的文本数据交互格式(2)json和字典以一样一、将python数据类型换成字典json.dump  json.dumps二、将json格式转换成python类型(1)dumps 将python类型转换成json格式importjsond={"name":"zs","age":18}print(type(d))#<class'di......
  • 流浪动物领养系统网站设计与实现[SSM+MySQL+JSP]
    目录系统展示项目背景系统设计总结系统展示项目背景当前社会各行业领域竞争压力非常大,随着当前时代的信息化,科学化发展,让社会各行业领域都争相使用新的信息技术,对行业内的各种相关数据进行科学化,规范化管理。这样的大环境让那些止步不前,不接受信息改革带来的信息技术......
  • 基于JSP客户关系管理系统的设计与实现的计算机毕设源码+论文
    摘要:本客户关系管理系统是使用JSP编程语言和SQLServer2000数据库共同来完成的,采用面向对象方法,对客户关系管理系统进行设计与实现。分析设计了客户关系管理系统的静态模型和动态模型,完成了系统开发的分析、设计和实现的工作。本客户关系管理系统通过Web方式完成用户与系统的交互,系......
  • js实现网页端录音功能
    1、代码首先安装依赖包:recorderxnpminstallrecorderx-S<template><divclass="container"><divclass="mt-30"><el-button@click="onStartRecord">开始录音</el-button><el-button@click......
  • asp.net webapi 控制器中获取appsettings.json 中的数组对象
    appsettings.json文件内容: {"Logging":{"LogLevel":{"Default":"Information","Microsoft.AspNetCore":"Warning"}},"MyConfigKey":"MyConfigValue"......
  • 基于JSP+SQL英语在线考试系统毕业设计整套的计算机毕设源码+论文
    摘要伴随着Internet技术在各个领域的广泛应用,当今社会已经进入信息时代,信息技术革命使社会的各个领域都发生了翻天覆地的变化,计算机,网络技术也渗透到了学校的日常管理当中去。而且网络化的管理也适合现在人的生活需求。在线考试系统以其较高的实用功能、高效率的管理手段深受各......
  • 快速上手高德JS API——以可视化公交站点线路为例
    前言在利用高德地图进行开发时,我们经常需要使用不同的API来实现特定的功能。为了帮助开发者快速定位所需API并掌握正确的使用方法,本文将以可视化任意公交站点路线为例,分享相关经验。根据需求粗略匹配参考示例在开始写代码我都会思考一下该功能的实现逻辑是什么:1、通过什么方式......
  • JavaScript For 循环示例
     零食故事:假设您有一篮子零食:constsnacks=['apple','banana','chocolate'];现在,您想与您的朋友分享这些零食。但你不是把整个篮子都给他们,而是把每件零食都拿出来,一一递给他们:console.log(...snacks);//output:applebananachocolate...(摊开)操作符就像是把......