我做在我的算法复杂性类的研究,我需要知道,如果有一种算法任何其他复杂,我所知道的和研究的是2种 1是在大O复杂性是时间和性能等 2-是空间复杂度是记忆的复杂性, 做算法有任何其他种类的复杂性?算法是用我错过的其他东西来衡量的吗?算法的复杂性能和空间
0
A
回答
5
在渐近的算法的复杂性而言 - 对,算法(和问题)在空间和时间上被测量。
然而,有很多我能说些什么。我会尽力解决一些问题:
空间/时间消耗是从分析的方法得出
有分析算法的4种常见方法,用于空间和时间。请记住,big-O是一组函数,但是如何导出函数?的复杂性的功能是根据分析的方法,该方法是(通常)以下之一得到:
- 最好的情况
- 平均情况
- 最坏情况
- Amortized Analysis
这些方法中的每一个都可以用于任何算法 - 并且结果不保证是相同的。例如,快速排序具有最差情况时间复杂度和O(nlogn)
平均情况时间复杂度。
多台套:
除了大O表示法,我们还可以使用其他符号来表示的复杂性。附加公共符号是(由使用的通用性):
- 大西塔(Θ)
- 大欧米茄(Ω)
- 小O
- 小的ω(ω)
不与分析方法相混淆:每个大西塔/大O /符号的......可与任何分析方法配对(最坏情况/平均情况/ ...)
更多细节上大西塔,大O和差异打赌吐温他们可以在this thread
复杂性理论中找到:
在理论"Complexity Theory"领域 - 我们分析问题,不算法。在这个领域,我们关心的一个问题可以多项式解决(即,如果输入大小ñ,那么问题就可以在ň一些力量解决),多项式验证(给出可能的解决方案,检查它是否正确)。但是,还有其他类。
常见的复杂性类是:
另外 - 我们有兴趣,如果问题是可以解决的/可判定的。描述的问题有解常见的类别是:
真实世界:
在现实世界中的应用程序 - 我们关心的不仅是理论上的空间/时间复杂性,而且关于常量(一个算法占用一半的时间尽管他们可以处于相同的复杂等级,但我作为另一个人更好。这是因为复杂类忽略了常量。)。
我们还考虑了程序/算法的实现时间和可维护性。
相关问题
- 1. 时间复杂度和空间复杂度,如何计算空间复杂度
- 2. 计算函数的空间复杂度和时间复杂度
- 3. 递归算法的空间复杂度
- 4. 时间和空间复杂的语言复杂性
- 5. 空间复杂性复发
- 6. 减少算法时间的复杂性
- 7. 分析算法的时间复杂性
- 8. 我算法的时间复杂性
- 9. 时间递归算法的复杂性
- 10. 回文算法的时间和空间复杂
- 11. JBIG压缩算法的空间和时间复杂性,大O符号?
- 12. 试图了解这种算法的空间复杂性
- 13. 算法的复杂性和STL :: vector的
- 14. foo算法的复杂性
- 15. 算法的复杂性
- 16. 算法的复杂性
- 17. Dijkstra算法的复杂性
- 18. 函数的复杂性和算法
- 19. 算法算法的时间复杂度
- 20. 时间和空间复杂
- 21. 算法复杂性分析
- 22. CNN AlexNet算法复杂性
- 23. 算法复杂度时间
- 24. 计算时间和空间复杂度来删除重复项
- 25. 如何计算算法的复杂性?
- 26. 无法总结算法的复杂性
- 27. 计算时间代码的复杂性
- 28. C++ STL容器的空间复杂性
- 29. 如何计算算法时间复杂
- 30. 算法时间复杂度算例
感谢,似乎清晰和完美你可以请让我知道,如果有一个列表algothims有复杂的空间和时间,如果你没有记在心里没有烦恼 – user1760556
看看[在维基百科算法列表] (http://en.wikipedia.org/wiki/List_of_algorithms)。几乎所有算法在其页面中都有其复杂性。 – amit
@GregRos:感谢您的编辑。答案现在更容易理解。你做了很棒的工作来评估我的英语 - 谢谢你。 – amit