数据结构时间复杂度怎么求?

 我来答
匿名用户
推荐于2018-10-15
展开全部
简单理解,时间复杂度就是执行语句被调用了多少次。
(1)如果只调用了一次,如:
x=5;
if(x<-4)
{x=x+4;}
else
{x=x+3;}
在大括号中的内容,只会调用一个语句,那么O(n)=1;
(2)如果调用了两次,如:
x=5;
if(x<-4)
{x=x+4;}
else
{x=x+3;}
x=x+56;
在大括号中的内容,只会调用一个语句,但是在最后,还有一个计算公式要调用语句;总共加起来就是调用2次。那么O(n)=2;
(3)用1个FOR循环调用
for(x=0;x<n;x++)
{x=x+1;}
x会从0到n-1循环,执行的语句就是将当前x值加入新的x中,总共调用n次;那么O(n)=n;
(4)用2个嵌套FOR循环调用
for(x=0;x<n;x++)
{
for(y=1;y<=n;y++)
{x=x+y;}
}
遇到嵌套循环,可以先将外面的FOR语句中的变量固定为初始值x=0,主要看里面的FOR语句的时间复杂度,很明显,里面语句执行次数是从1到n总共调用n次,O(n)=n;这还只是x=0时的调用。x可以从0到n-1,共n次。每次调用都会执行n次调用y的情况,因此,执行语句x=x+y;总共会调用n*n次。O(n)=n^2。

数执行语句的执行次数,就是时间复杂度。注意:
(1)找到正确的执行语句。
(2)for循环中的初始值和终止值。
for(i=0;i<n;i++) i值变化是从0到n-1,共n次。
for(i=0;i<=n;i++) i值变化是从0到n,共n+1次。
(3)注意for循环的调用顺序,从里面到外面进行的。
百度网友1fc36d4
2012-12-11 · TA获得超过3128个赞
知道大有可为答主
回答量:1497
采纳率:100%
帮助的人:1811万
展开全部
一般的,一次计算那么复杂度为1
循环,则看循环次数,这个可以根据循环条件来,比如for(int i=0;i<10;i++)则复杂度就是10.一般写出O(n) n是循环次数

如果双重循环,则是O(m*n)

看书上的例子吧
来自:求助得到的回答
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
帐号已注销
2020-03-06 · TA获得超过8502个赞
知道小有建树答主
回答量:7.9万
采纳率:3%
帮助的人:3836万
展开全部
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
胡珖
2018-09-13
知道答主
回答量:1
采纳率:0%
帮助的人:818
引用hyfrain的回答:
简单理解,时间复杂度就是执行语句被调用了多少次。
(1)如果只调用了一次,如:
x=5;
if(x<-4)
{x=x+4;}
else
{x=x+3;}
在大括号中的内容,只会调用一个语句,那么O(n)=1;
(2)如果调用了两次,如:
x=5;
if(x<-4)
{x=x+4;}
else
{x=x+3;}
x=x+56;
在大括号中的内容,只会调用一个语句,但是在最后,还有一个计算公式要调用语句;总共加起来就是调用2次。那么O(n)=2;
(3)用1个FOR循环调用
for(x=0;x<n;x++)
{x=x+1;}
x会从0到n-1循环,执行的语句就是将当前x值加入新的x中,总共调用n次;那么O(n)=n;
(4)用2个嵌套FOR循环调用
for(x=0;x<n;x++)
{
for(y=1;y<=n;y++)
{x=x+y;}
}
遇到嵌套循环,可以先将外面的FOR语句中的变量固定为初始值x=0,主要看里面的FOR语句的时间复杂度,很明显,里面语句执行次数是从1到n总共调用n次,O(n)=n;这还只是x=0时的调用。x可以从0到n-1,共n次。每次调用都会执行n次调用y的情况,因此,执行语句x=x+y;总共会调用n*n次。O(n)=n^2。

数执行语句的执行次数,就是时间复杂度。注意:
(1)找到正确的执行语句。
(2)for循环中的初始值和终止值。
for(i=0;i<n;i++) i值变化是从0到n-1,共n次。
for(i=0;i<=n;i++) i值变化是从0到n,共n+1次。
(3)注意for循环的调用顺序,从里面到外面进行的。
展开全部
那个二次循环的时间自由度错了,x的变化要注意
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
海边小城60
2019-12-21 · TA获得超过1679个赞
知道答主
回答量:3055
采纳率:1%
帮助的人:189万
展开全部
结构时间复杂度怎么求?好刀起来了没啊怎么了呢红包
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式