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



有哪些见过的时间复杂度为无限大的算法? 第1页

  

user avatar   Caproner 网友的相关建议: 
      

在算法的五个性质中就有一个有限性。

1. 输入:一个算法必须有零个或以上输入量。
2. 输出:一个算法应有一个或以上输出量,输出量是算法计算的结果。
3. 明確性:算法的描述必须无歧义,以保证算法的實際执行结果是精確地符合要求或期望,通常要求實際執行結果是确定的。
4. 有限性:依據圖靈的定義,一個演算法是能夠被任何圖靈完備系統模擬的一串運算,而圖靈機只有有限個狀態、有限個輸入符號和有限個轉移函數(指令)。而一些定義更規定演算法必须在有限個步骤内完成任務。
5. 有效性:又称可行性。能够实现,算法中描述的操作都是可以通过已经实现的基本运算执行有限次来实现。

【以上引用自Wikipedia:算法 - 维基百科,自由的百科全书

换言之,如果有一个时间复杂度为无穷大的程序的话,那它严格地讲就不是算法了。。

从这个角度回答的话,不存在时间复杂度为无穷大的算法。


当然,存在最坏情况会到正无穷但是平均情况下是有穷的算法。

例如说猴子排序

最坏情况的时间复杂度为O(+∞),期望时间复杂度为O(n*n!)

不过按照定义来看,猴子排序算不算满足有限性还是个问题。。




  

相关话题

  如果中国人民银行给中国14亿老百姓每人发个1000万,对中国和世界各有什么影响? 
  如何看待两次 IOI 金牌,一次 ACM 全球总决赛亚军的清华大学计算机系毕业生去高中当信息学教师? 
  软件工程女生毕业不想干程序员能做什么IT类的职位呀? 
  程序员年龄增大后的职业出路是什么? 
  为什么leetcode等OJ上Cpp的提交都以class solution而不是main函数作为入口? 
  C/C++编程有哪些没什么用,但让人不明觉厉又不至于太奇怪的写法? 
  在内存特定位置填数据后,placement new 是否完全等价与cast? 
  如何滴水不漏的学完C语言? 
  传统的try-catch异常处理是否是编程语言发展中的弯路? 
  运行时异常处理程序是如何实现的? 

前一个讨论
什么是「红卫兵思维」?
下一个讨论
关于 C++ 顶层 const 和底层 const?





© 2025-05-02 - tinynew.org. All Rights Reserved.
© 2025-05-02 - tinynew.org. 保留所有权利