您的位置:首页 > 其它

算法的复杂度的渐近表示方法

2008-08-05 14:34 176 查看
一个算法的时间复杂度,指算法运行的时间。假设数据输入规模是n,算法的复杂度可以表示为f(n)的函数一。大O记号假设f(n)和g(n)的定义域是非负整数,存在两个正整数c和n0,使得n>n0的时候,f(n)<c*g(n),则f(n)=O(g(n))。可见O(g(n))可以表示算法运行时间的上界。O(g(n))表示的函数集合的函数是阶数不超过g(n)的函数。二。Ω记号Ω记号与大O记号相反,他可以表示算法运行时间的下界。Ω(g(n))表示的函数集合的函数是所有阶数超过g(n)的函数。三。Θ记号Θ记号介于大O记号和Ω记号之间。他表示,存在正常数c1,c2,n0,当n>n0的时候,c1*g(n)<f(n)<c2*g(n),则f(n)=Θ(g(n))。他表示所有阶数与g(n)相同的函数集合。四。小o记号f(n)=o(g(n))当且仅当f(n)=O(g(n))且f(n)≠Ω(g(n))。也就是说小o记号可以表示时间复杂度的上界,但是一定不等于下界。五。例子假设f(n)=2n^2+3n+5,f(n)=O(n^2)或者f(n) = O(n^3)或者f(n)=O(n^4)或者……f(n)=Ω(n^2)或者f(n)=Ω(n)或者f(n)=Ω(1)f(n)=Θ(n^2)f(n) = o(n^3)或者f(n)=o(n^4)或者f(n)=o(n^5)或者……注:n^2表示n的平方,以此类推。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: