百科问答小站 logo
百科问答小站 font logo



算法老师劝学生放弃学习 JavaScript,我该怎么办? 第1页

  

user avatar   miloyip 网友的相关建议: 
      

談一個技術上的原因。

學習算法需要分析算法的時間和空間複雜度

JavaScript的標準ECMA-262[1]並沒有指明各種操作的複雜度,各個腳本引擎的實現可能會不一樣。

而C++本身較JS底層、透明,而且C++的標準庫也會指明各種操作的複雜度,例如upper_bound()是對數時間複雜度[2]、vector::push_back()是分攤常數時間複雜度[3]。

所以,使用JavaScript實現算法時,相比C++,可能較難分析算法的複雜度。

[1]

ecma-international.org/

[2]

std::upper_bound

[3]

std::vector::push_back

---------------------------------

一些之前对

@winter

的回应,复制于此:

每個語言都有底層,但C++比JS底層,我只是說C++比JS容易分析複雜度。

實際上,申請O(n)內存時某個操作系統申請了O(n^2)內存,這個可能性是存在的,只是我們一般能相信這個操作只會分配O(n)的內存。

即使有偽代碼,也難判定複雜度。例如對象可以用hash table或是sorted map實現,當中各個操作的時間複雜度就不一樣。

那個reference是按standard寫的,有些會說明C++11和之前的分別。例以在我的答案中提及list::size()在C++11規定要O(1),而C++03則不是。




  

相关话题

  怎么证明每个位上的数字之和可以被3整除的数可以被3整除? 
  100个金币,只有1个略重,其余99个一样重。给你一个天平,最少称几次能确保找出那个略重的? 
  国内做前端年薪有上50W的吗? 
  感觉算法在程序员中快被吹上天了,如果只是搞编程的话,是不是没必要死磕算法? 
  前端程序员刚进入公司上来给我了一套五年前的管理系统代码让我吃透了改bug,根本看不懂想离职了怎么办? 
  电子设备(如电脑)内置时钟的算法是如何“分辨/度量”出一秒的长度的? 
  如何看待 2021 年图灵奖授予美国计算机科学家 Jack J. Dongarra? 
  【校招面试】关于Typescript和ES6的对比? 
  为什么那么多公司做前后端分离项目后端响应的 HTTP 状态一律 200? 
  有什么办法可以用纯 CSS 在现代浏览器下实现单屏内容时 footer 贴底,多屏内容时 footer 随内容向下? 

前一个讨论
C/C++ 小括号中为何不能声明变量的同时对其赋值?
下一个讨论
为什么有一些程序员认为开源有助于发现软件中的缺陷?





© 2025-06-27 - tinynew.org. All Rights Reserved.
© 2025-06-27 - tinynew.org. 保留所有权利