【时间复杂度的计算】

目录

  • 一、时间复杂的的概念
    • 1、定义
    • 2、基本计算规则
  • 二、单层循环时间复杂度计算公式
  • 三、双层循环时间复杂度计算公式
  • 四、多层循环时间复杂度计算公式
    • 1、法一:抽象为计算三维物体的体积
    • 2、法二:列式求和

一、时间复杂的的概念

1、定义

时间复杂度(time complexxity)是一个定性描述该算法运行时间的函数,它代表算法输入值的字符串的长度。时间复杂度常用O表述,不包括这个函数的低阶项和首项系数。

时间复杂度的大小比较:
在这里插入图片描述
时间复杂度的分类:

  1. 算法完成工作最少需要多少基本操作叫做最优时间复杂度,是一种最乐观理想的状态;
  2. 算法完成工作需要多少基本操作叫做最坏时间复杂度,是算法的一个保障;
  3. 算法完成工作平均需要多少基本操作叫做平均时间复杂度,它可以均匀全面地评价一个算法的好坏。

2、基本计算规则

  1. 基本操作即只有常数项,认为其时间复杂度为O(1);
  2. 顺序结构,时间复杂度按加法计算;
  3. 循环结构,时间复杂度按乘法计算;
  4. 分支结构,时间复杂度取最大值;
  5. 判断一个算法效率时,往往只需要关注操作的最高次项,其他次要项和常数项可以忽略;
  6. 在没有特殊说明时,我们所分析的时间复杂度都是最坏时间复杂度。

二、单层循环时间复杂度计算公式

计算步骤:

  1. 列出循环趟数t及每轮循环i的变化值
  2. 找到t与i的关系
  3. 确定循环停止条件
  4. 联立两式解方程
  5. 写结果

例题分析一:

i = n*n;
whlie(i != 1)
    i = i/2;

第一步:列出循环趟数t和每轮循环i的变化值

t0123
in^2(n^2)/2(n^2)/4(n^2)/8

第二步:找到t和i的关系
i = (n2)/2t
第三步:确定循环停止条件
i =1
第四步:联立第二步和第三步两式解方程:
在这里插入图片描述
所以得到的时间复杂度为:
在这里插入图片描述
例题分析二:

x = 0;
whlie(n>=(x+1)*(x+1))
    x = x+1;

第一步:列出循环趟数t和每轮循环x的值:

t0123
x0123

第二步:找到t与x的关系:
t = x
第三步:确定循环停止的条件
在这里插入图片描述
第四步:联立第二步和第三步解方程
在这里插入图片描述
所以时间复杂度为:
在这里插入图片描述

三、双层循环时间复杂度计算公式

解题步骤:

  1. 列出循环中i的变化值
  2. 写出内层语句的执行次数
  3. 求和,写结果

例题分析一:

int m = 0, i , j;
for(i = 1; i<=n;i++)
    for(j = 1;j<=2*i;j++)
        m++;

第一步:列出循环中i的变化值

i1234567n

第二步:写出内层语句的执行次数

内层语句执行次数2468102*n

第四步:求和,写结果
2+4+6+8+…+2*n = n(n+1)
所以时间复杂度为:
在这里插入图片描述
例题分析二:

for(i = 0;i<n;i++)
    for(j=0;j<m;j++)
        a[i][j] = 0;

第一步:列出循环中i的变化值

i01234n-1

第二步:写出内层语句执行次数

内层语句执行次数mmmmm

第三步:求和,写结果
m * (n-1-0+1) = m*n
在这里插入图片描述
例题分析三:

count = 0;
for(k=1;k<=n;k*=2)
    for(j=1;j<=n;j++)
        count ++;

注意此处外层循环中不是k++而是k *=2,所以先计算外层循环的单层时间复杂度:

循环趟数t123456
k12481632

循环趟数t和k关系:
在这里插入图片描述
循环停止条件为:k =n
联立两式,得:
在这里插入图片描述
外层的时间复杂度就为:
在这里插入图片描述
计算内层时间复杂度为O(n)
总体时间复杂度为:
在这里插入图片描述

四、多层循环时间复杂度计算公式

例题分析一:

for(i=0;i<=n;i++)
    for(j=0;j<=i;j++)
       for(k=0;k<j;k++)

1、法一:抽象为计算三维物体的体积

在这里插入图片描述
时间复杂度为:
在这里插入图片描述

2、法二:列式求和

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/784347.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

java 参数传递(尤其注意参数是对象的情况)

8大基本数据类型为 值传递 类和数组为 引用传递&#xff0c;传递的是地址 但是要注意虽然类是引用传递&#xff0c;但是要注意&#xff0c;调用方法是新开一个栈 因此如果进行p null或者 Person p new Person()等语句&#xff0c;要格外注意&#xff1a; 如果主函数再次输出…

C/C++内存分布

1.内存分布简略图 2.全局变量和静态变量的区别 (1)局部静态变量&#xff1a;存储在数据段中&#xff0c;局部静态变量的作用域在当前函数中&#xff0c;出了函数就不能使用该变量&#xff0c;但局部静态变量的生命周期是在整个程序间&#xff0c;局部静态变量要运行到这一行才…

贝叶斯估计(1):期末大乱炖

写在前面&#xff01; 1 先验分布和后验分布 三种信息&#xff1a;总体信息、样本信息、先验信息 总体信息&#xff1a;“总体是正态分布”&#xff1b;样本信息&#xff1a;总体抽取的样本提供的信息&#xff0c;是最新鲜的信息&#xff1b;先验信息&#xff1a;在抽样之前就…

019-GeoGebra中级篇-GeoGebra的坐标系

GeoGebra作为一款强大的数学软件&#xff0c;支持多种坐标系的使用&#xff0c;包括但不限于&#xff1a;笛卡尔坐标系&#xff08;Cartesian Coordinate System&#xff09;、极坐标系&#xff08;Polar Coordinate System&#xff09;、参数坐标系&#xff08;Parametric Coo…

第二证券股市知识:股票填权是怎么回事?利好还是利空?

1、股票填权的含义 股票填权是指在除权除息之后的一段时刻内&#xff0c;假设多数投资者看好该个股&#xff0c;股票的价格超过除权除息的基准价就叫做填权。上市公司假设能持续分红&#xff0c;就会向市场传递积极信号&#xff0c;招引更多投资者买入&#xff0c;越来越多的投…

Thingsboard 系列之通过 ESP8266+MQTT 模拟设备上报数据到平台

前置工作 Thingsboard平台ESP 8266 NodeMCU 开发板IDE&#xff1a; Arduino 或 VScode 均可 服务端具体对接流程 系统管理员账号通过 Thingsboard 控制面板创建租户等信息并以租户账号登录 实体 —> 设备维护具体设备信息 创建完成后通过管理凭据修改或直接复制访问令牌…

磁致伸缩液位计的应用领域

磁致伸缩液位计作为一种高精度、高稳定性的液位测量设备&#xff0c;在众多行业中都有着广泛的应用。接下来&#xff0c;我们将从多个角度详细探讨磁致伸缩液位计在不同领域的应用情况。 石油化工行业 在石油化工行业中&#xff0c;磁致伸缩液位计主要用于储罐、反应器和管道等…

太实用了吧?手把手教你华为eNSP模拟器桥接真实网络!

号主&#xff1a;老杨丨11年资深网络工程师&#xff0c;更多网工提升干货&#xff0c;请关注公众号&#xff1a;网络工程师俱乐部 晚上好&#xff0c;我的网工朋友。 今天聊聊eNSP桥接正式网络&#xff0c;就是把eNSP桥接进真实的网络&#xff0c;利用我们的物理网卡通过实体路…

数学建模论文写作文档word

目录 1. 摘要写法1.1 确定题目与方法1.2 编写开头段落1.3 填写问题一1.4 重复步骤3填写其他问题1.5 编写结尾段落1.6 编写关键词 2. 问题重述2.1 问题背景2.2 问题提出 3. 问题分析4. 问题X模型的建立与求解5. 模型的分析5.1 灵敏度分析5.2 误差分析&#xff08;主要用于预测类…

linux基础—目录和文件操作

1&#xff0c;列出目录和文件的详细信息 ls: ls -l ls -lt 2&#xff0c;认识文件 第一列 左边的一组排序中&#xff0c;第一个字符是文件的类型&#xff0c;后面9个字符是文件的权限。 第一个字符主要有3种情况&#xff1a; d表示目录、-表示文件&#xff0c;l表示链接 第…

【回溯算法经典题目解析】

1. 什么是回溯算法 回溯算法是⼀种经典的递归算法&#xff0c;通常用于解决组合问题、排列问题和搜索问题等。 回溯算法的基本思想&#xff1a;从一个初始状态开始&#xff0c;按照⼀定的规则向前搜索&#xff0c;当搜索到某个状态⽆法前进时&#xff0c;回退到前⼀个状态&am…

背包问题转换

如何转换成背包问题呢&#xff0c;我们可以把每个质数当成一个重量 #define _CRT_SECURE_NO_WARNINGS #include<bits/stdc.h> using namespace std;#define int long long int record[1005]; void fun() {//record[2] 1;for (int i 2; i < 1000; i) {if (!record[…

JDBC和数据库连接池

1 JDBC概述 1.1 数据持久化 持久化(persistence)&#xff1a;把数据保存到可掉电式存储设备中以供之后使用。大多数情况下&#xff0c;特别是企业级应用&#xff0c;数据持久化意味着将内存中的数据保存到硬盘上加以”固化”&#xff0c;而持久化的实现过程大多通过各种关系数…

鸿蒙语言基础类库:【@ohos.url (URL字符串解析)】

URL字符串解析 说明&#xff1a; 本模块首批接口从API version 7开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。开发前请熟悉鸿蒙开发指导文档&#xff1a;gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。 导入…

第一百四十九节 Java数据类型教程 - Java子字符串、字符串转换

Java数据类型教程 - Java子字符串 获取子字符串 我们可以使用substring()方法来获取字符串的子部分。 我们可以将开始索引作为参数&#xff0c;并返回一个从开始索引开始到字符串结尾的子串。 我们还可以将开始索引和结束索引作为参数。 它返回从开始索引开始的子字符串和小…

使用预加载库优化 PostgreSQL 函数#postgresql认证

在 POSTGRESQL 中执行函数和过程 为了理解 PostgreSQL 的工作原理&#xff0c;我们首先要看一个简单的函数调用。下一个清单显示了一些简单的PostGIS代码&#xff1a; PgSQL test# timing Timing is on. test# SELECT * FROM hans.points WHERE id 1;id │ …

【工具分享】零零信安攻击面管理平台

文章目录 00SEC-ASM™功能介绍功能演示 最近闲来无事&#xff0c;到处网上冲浪&#xff0c;无意间发现了长亭云图攻击面管理平台&#xff0c;无奈需要授权才能使用&#xff0c;于是就找到了平替&#xff1a;零零信安攻击面管理平台。 长亭云图攻击面管理平台&#xff1a;https:…

代码随想录-Day50

1143. 最长公共子序列 给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 &#xff0c;返回 0 。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原字符串在不改变字符的相对顺序的情况下删除某些…

Kotlin linkedMapOf filterKeys

Kotlin linkedMapOf filterKeys fun main(args: Array<String>) {val lhm linkedMapOf<String, Any>(Pair("name", "phil"), //因为key相同都为 name&#xff0c;被后面的覆盖。Pair("year", 2024),Pair("name", "f…

【TB作品】51单片机 Proteus仿真 00013红外proteus仿真循迹避障小车

实验报告&#xff1a;智能小车系统设计与实现 一、背景介绍 本实验旨在设计并实现一个基于STC89C52单片机控制的智能小车系统。该系统通过超声波传感器进行避障&#xff0c;通过红外接收器实现远程控制&#xff0c;同时具备循迹功能。整个系统的核心是单片机&#xff0c;它通…