zoukankan      html  css  js  c++  java
  • 时间复杂度概念

    相比毕业这么长时间来说,以前的知识大部分已经还给了老师,现在回想一下很后悔,决定逐渐的巩固一下以前的概念,想必对自己以后对程序的理解会有很大的帮助。下面开始:

    简单理解,时间复杂度就是执行语句被调用了多少次。
    (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循环的调用顺序,从里面到外面进行的。
    天生我才必有用,千金散去还复来!
  • 相关阅读:
    Vue学习笔记(一)
    Visual Studio Code (vscode)自定义用户代码段快速打出for循环等
    2019.5.5 JS相关
    项目搭建 相关
    2019.4.26 响应式布局
    android The content of the adapter has changed but ListView did not receive a notification 错误的解决方案
    ListView 加载数据时 触摸报错
    android 代码中使用textAppearance
    c/c++ 指针函数 和 函数指针
    c/c++ 指针数组 和 数组指针
  • 原文地址:https://www.cnblogs.com/Jack-Lu/p/3154151.html
Copyright © 2011-2022 走看看