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

dsa 与 js:用 javascript 解释大 o 表示法

废话不多说,我们直接进入正题吧。什么是大 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 < numbers.length; i++) {  console.log(numbers[i]);}

在此示例中:

如果数组有 5 个元素,则循环将运行 5 次。

如果数组有 100 个元素,则循环将运行 100 次。

如果数组有 n 个元素,则循环将运行 n 次。

示例 2:在数组中搜索值

假设你想查找数组中是否存在特定值:

function findvalue(arr, target) {  for (let i = 0; i < arr.length; i++) {    if (arr[i] === target) {      return true;    }  }  return false;}

在此示例中:

如果数组有 10 个元素,循环可能会运行最多 10 次来查找值。

如果数组有 1,000 个元素,则循环可能最多运行 1,000 次。

对于 n 个元素,在最坏的情况下循环可能会运行 n 次。

因此,数组越大,检查每个元素所需的时间就越长,使其o(n)

o(n²) – 二次时间

o(n²) 表示完成算法所需的时间随着输入大小的增加呈指数级增加。具体来说,如果输入大小加倍,则所需时间会增加四倍(因为 2² = 4)。如果输入增加三倍,时间就会增加 九倍(因为 3² = 9)。

当您有嵌套循环时,通常会发生这种情况,其中一个循环迭代输入,然后在该循​​环内,另一个循环也迭代相同的输入。

数组上的嵌套循环: 假设您有一个数组,并且您想要将每个元素与数组中的每个其他元素进行比较。这是一个例子:

怪兽智能全息舱 怪兽智能全息舱

专业的AI数字人平台,定制数字人专属IP

怪兽智能全息舱 16 查看详情 怪兽智能全息舱

let numbers = [10, 20, 30, 40, 50];for (let i = 0; i < numbers.length; i++) {  for (let j = 0; j < numbers.length; j++) {    console.log(numbers[i], numbers[j]);  }}

这是发生的事情:

外循环运行n次(其中n是数组的长度)。

对于外循环的每次迭代,内循环也运行n次。

因此,对于数组中的每个项目,您都会再次循环遍历每个项目。如果数组有 5 个元素,则 5 次外循环迭代中的每一次内循环都会运行 5 次,使其总共运行 25 次 (5 × 5 = 25)。

这使得时间复杂度 o(n²),因为对于 n 个元素,您正在执行 n × n 操作。

o(n²) 总结: 当您有嵌套循环时,就会发生 o(n²),其中两个循环都迭代相同的输入。所花费的时间随着输入的大小呈二次方增长。与 o(n)o(log n) 相比,它的速度较慢,因为随着输入大小的增加,操作数量增长得更快。

二次时间在冒泡排序等算法或需要比较数据集中每对项目的问题中很常见。

o(log n) – 对数时间

我认为这个需要更多的关注和仔细来掌握这个概念。

o(log n) 中,时间 随着输入大小的增大而增加,但与其他时间复杂度(如 o( n)o(n²).

这里是关键思想: 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 <= right) {    let mid = Math.floor((left + right) / 2);    if (arr[mid] === target) {      return mid;    } else if (arr[mid] < target) {      left = mid + 1; // Search the right half    } else {      right = mid - 1; // Search the left half    }  }  return -1; // Target not found}

运作原理:

首先将数组的中间元素与目标进行比较。

如果中间元素是目标,则完成。

如果中间元素小于目标,则丢弃数组的左半部分并仅在右半部分搜索。

如果中间元素较大,则丢弃右半部分并在左半部分搜索。

每次,您都会将数组切成两半

最后的话

大 o 表示法 用于描述算法的时间或空间复杂度如何随着输入大小的增长而变化。它为我们提供了一种讨论算法效率的方法,特别是当输入变大时。 big o 专注于最坏情况,帮助我们了解算法性能的上限。

以上就是DSA 与 JS:用 JavaScript 解释大 O 表示法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/898604.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月28日 19:08:14
下一篇 2025年11月28日 19:08:35

相关推荐

  • PHP中__debugInfo有什么用?

    在php中,__debuginfo魔术方法的作用是定制对象在调试时的输出。1)它允许你控制var_dump()函数的输出内容和格式,2)通过选择性展示对象属性或格式化输出,3)保护敏感数据,4)简化复杂结构,5)自定义输出格式,以提升调试体验。 在PHP中,__debugInfo魔术方法的作用是定制…

    2025年12月10日
    000
  • PHP中如何加密和解密数据?

    在php中,可以使用aes-256-cbc算法进行数据的加密和解密。1.使用openssl_encrypt函数加密数据,并生成随机iv;2.使用openssl_decrypt函数解密数据,确保使用相同的密钥和iv;3.注意密钥管理和iv的唯一性,以增强安全性。 在PHP中加密和解密数据是开发过程中常…

    2025年12月10日
    000
  • php教程教程从入门到精通 从基础到高级的php学习路径

    从初学者到精通php的学习路径包括以下步骤:1. 安装和配置php环境,推荐使用xampp或wamp。2. 学习php基本语法,如变量、数据类型、运算符等,并尝试编写简单的脚本。3. 掌握函数和数组的使用,编写更复杂的程序。4. 学习面向对象编程(oop),理解类、对象、继承等概念。5. 学习数据库…

    2025年12月10日
    000
  • PHP中如何实现数据加密?

    php中如何实现数据加密?在php中,可以使用openssl和mcrypt等内置函数和扩展库实现数据加密。1. 选择合适的加密算法,如aes或rsa。2. 使用aes加密时,需生成并管理初始化向量(iv)。3. 密钥管理至关重要,应安全存储并加密传输。4. rsa适用于小数据加密或密钥交换,但处理大…

    2025年12月10日
    000
  • PHP中foreach如何获取键和值?

    在php中,使用foreach循环可以遍历数组或对象,并获取键和值。1. 使用$key => $value语法可以同时获取键和值。2. 处理多维数组时,可以使用嵌套的foreach循环。3. 要修改原始数组,需要使用引用&$value。4. foreach通常比for循环更高效,尤其在…

    2025年12月10日
    000
  • PHP中如何实现数据验证?

    在php中实现数据验证可以使用手动验证、php内置函数和第三方库三种方法。1. 使用filter_var()等内置函数进行基本验证。2. 利用preg_match()进行正则表达式验证。3. 采用respectvalidation或symfonycomponentvalidator等第三方库简化复杂…

    2025年12月10日
    000
  • PHP中array_combine怎么合并键值?

    array_combine函数在php中用于将一个数组的元素作为键,另一个数组的元素作为值创建新数组。1)基本语法是$new_array = array_combine($keys, $values),确保$keys和$values长度相同。2)高级用法包括重新组织用户信息。3)注意事项:数组长度不…

    2025年12月10日
    000
  • PHP中字符串如何定义?

    php中定义字符串的方式有四种:1) 单引号字符串,不解析变量和转义字符;2) 双引号字符串,解析变量和某些转义字符;3) heredoc语法,允许变量解析,适合多行文本;4) nowdoc语法,不解析变量,类似单引号字符串。 在PHP中,字符串的定义方式多种多样,这让它既灵活又有趣。首先,最常见的…

    2025年12月10日
    000
  • php前后端分离怎么实现 php实现前后端分离的方法和技巧

    前后端分离的核心目的是提高开发效率和代码的可维护性。1)通过restful api、graphql和websocket等方法实现前后端分离,2)需要注意cors、版本控制、认证与授权、错误处理和日志等方面的技巧和最佳实践。 在我们开始探索 PHP 前后端分离的实现方法之前,让我们先回答一个关键问题:…

    2025年12月10日
    000
  • PHP中索引数组和关联数组有什么区别?

    php中索引数组和关联数组的区别在于:索引数组使用数字作为键,适合存储相同类型的数据列表;关联数组使用字符串作为键,适合存储键值对数据。1. 索引数组简单高效,适用于用户列表等场景,但缺乏灵活性。2. 关联数组灵活且可读性高,适用于用户信息等复杂数据,但性能稍差。选择时需根据具体需求决定。 PHP中…

    2025年12月10日
    000
  • PHP中如何实现数据同步?

    在php中实现数据同步可以使用以下方法:1. 使用cron作业,通过定时执行php脚本实现数据同步,适合数据更新频率不高的场景。2. 使用消息队列,如rabbitmq,适用于需要实时同步的场景。3. 使用触发器和存储过程,利用数据库功能实现实时数据同步,但需考虑对数据库性能的影响。 在PHP中实现数…

    2025年12月10日
    000
  • PHP中如何实现多线程?

    php不支持多线程,但可以通过以下方法实现类似效果:1. 使用pcntl扩展创建多进程,适用于简单并行任务,但不支持windows。2. 使用pthread扩展实现真正的多线程,但可能遇到兼容性和调试问题。3. 使用reactphp库进行异步并发处理,适合高并发场景,但学习曲线较陡。 在PHP中实现…

    2025年12月10日
    000
  • PHP中如何验证ISWC字符串?

    在php中验证iswc字符串的方法是:1. 使用正则表达式验证格式”t-xxx.yyy.z”。2. 计算校验位,通过去掉”t-“和点后,按权重计算总和,取余数并计算校验位,最后与字符串最后一位比较。 在PHP中验证ISWC(International …

    2025年12月10日
    000
  • PHP中单引号和双引号字符串的区别?

    PHP中单引号和双引号字符串的区别?在PHP中,单引号和双引号字符串看似简单,但它们之间的差异却常常让开发者陷入困惑。单引号和双引号的选择不仅仅是个人偏好,它直接影响到代码的性能和功能。让我们深入探讨一下这些差异,以及在实际开发中如何选择合适的引号类型。 首先要明确的是,单引号字符串在处理时更快,因…

    2025年12月10日
    000
  • php数据库增删改查语句 php数据库操作的基本语句教程

    需要掌握数据库操作的基本语句,因为它们能使数据处理更灵活、高效,并优化数据库设计和应用性能。在php中,这些操作包括:1. 插入数据,使用insert into语句;2. 查询数据,使用select语句;3. 更新数据,使用update语句;4. 删除数据,使用delete语句。 在学习PHP数据库…

    2025年12月10日
    000
  • PHP中如何实现中间件模式?

    在php中实现中间件模式的关键是通过定义middleware接口和requesthandler类来管理中间件栈。具体步骤包括:1.定义middleware接口,要求实现handle方法;2.创建具体中间件类,如loggingmiddleware和authenticationmiddleware;3.…

    2025年12月10日
    000
  • PHP中如何实现策略模式?

    在php中实现策略模式可以通过以下步骤:1. 定义策略接口,如paymentstrategy。2. 创建具体策略类,如creditcardstrategy和alipaystrategy。3. 实现上下文类,如shoppingcart,用于动态设置和使用策略。策略模式使代码扩展性和复用性增强,但需注意…

    2025年12月10日
    000
  • PHP中__construct和__destruct的作用?

    在php中,__construct是对象的构造函数,用于初始化对象属性;__destruct是对象的析构函数,用于清理资源。1.__construct方法在对象创建时自动调用,初始化对象属性,如设置用户初始状态。2.__destruct方法在对象销毁时自动调用,进行清理工作,如关闭数据库连接,避免资…

    2025年12月10日
    000
  • PHP中如何实现数据导出?

    在php中实现数据导出的基本方法是通过服务器端脚本生成文件内容,然后通过http头部信息告诉浏览器将其作为文件下载。1. csv文件导出使用fputcsv函数生成,需注意http头部设置和字段转义处理。2. excel文件导出使用phpspreadsheet库,支持复杂格式但资源消耗高。3. 大数据…

    2025年12月10日
    000
  • php技术栈的常见三个步骤 php开发中的核心技术栈解析

    在php开发中,常见的三个步骤是:1. 设计:使用uml和mvc模式规划系统架构,提高代码可维护性。2. 开发:关注代码实现,确保安全性,使用composer管理依赖。3. 部署:利用docker容器化应用,简化部署过程。 在PHP开发中,常见的三个步骤是什么?这是一个非常好的问题,答案并不简单,因…

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信