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



一个单链表,长度未知,如何快速的找出位于中间的那个元素? 第1页

  

user avatar   Ivony 网友的相关建议: 
      

程序员看到算法就容易High起来,但老实说外行看热闹,内行看门道。我一直觉得算法这个东西用什么精妙来形容,算得上是外行看热闹。

在这个问题的答案下,有两个算法:

分别是

@蔡啸

@Irons Du

提供的,很显然前者的算法看起来比较精妙,而后者的算法看起来简直就是low爆了。

但事实上,不考虑vector扩容开销的话,这俩算法的时间复杂度都是O(n),前者的优势在于其只需要俩指针空间,后者则直接把整个链表变成了一个vector,

也就是说后者是用空间换时间。


所以说这个看似很low的算法也是有其意义的,因为这个很low的算法通过指针获取元素的次数只有n+1或n次,而前者则需要获取n+n/2次。

当然,我们知道通过指针获取元素的性能是极高的,而且,1.5n和n+1的时间复杂度都是O(n)。但是如果通过指针获取元素的性能变得极差的时候(例如根本就是个远程调用的话),那么这种low爆的算法就会摇身一变成为最精妙的算法,而原来精妙的算法又会变为最SB的做法了。


算法没有高下之分,场景才是最重要的。


一个程序员成熟的标志就是从看到算法就会high,到看到薪酬才会high,,XD,,,,




  

相关话题

  美团公开外卖订单分配算法,详解算法如何判断一个骑手的时间宽裕程度和顺路程度,有哪些值得关注的信息? 
  谁能最简单的详解椭圆曲线算法,secp256k1 是如何生成公钥和私钥的? 
  有哪些解决完之后让你拍案叫绝的算法问题? 
  有哪些你看了以后大呼过瘾的编程书? 
  正负样本极不平衡的问题? 
  用链表的目的是什么?省空间还是省时间? 
  你在生活中用过最高级的算法知识是什么? 
  五个囚犯先后从100颗绿豆中抓绿豆。抓得最多和最少的人将被处死,不能交流,可以摸出剩下绿豆的数量,谁的存活几率最大? 
  你认为最优美的数据结构是什么? 
  如何检验算法的正确性? 

前一个讨论
女性该为自己穿得少招惹了色狼而负一定责任吗?
下一个讨论
这种水果有类似菠萝和芒果的味道,是什么水果?





© 2025-03-29 - tinynew.org. All Rights Reserved.
© 2025-03-29 - tinynew.org. 保留所有权利