【2023】java数据结构-时间、空间复杂度分析

1、算法效率

算法效率分析分为两种:第一种是时间效率,第二种是空间效率。时间效率被称为时间复杂度,而空间效率被称作空间复杂度。 时间复杂度主要衡量的是一个算法的运行速度,而空间复杂度主要衡量一个算法所需要的额外空间

2、时间复杂度:

时间复杂度的定义:在计算机科学中,算法的时间复杂度是一个函数,它定量描述了该算法的运行时间。一个算法执行所耗费的时间

  • 大O表示法:不具体表示代码的真正的执行时间,而是表示代码执行时间随着数据规模的增长的变化趋势
  • 复杂度分享就是要捋清楚代码的执行次数和数据规模n之间的关系;
  1. O(1):只要代码的执行时间不随着n的增大而增大,这样的代码复杂度都是O(1)。 如:

    java 复制代码
    public void test01(int n){
    	int i = 0;
    	int sum =  0;
    	for(;1<100;i++){
    		sum = sum + i;
    	}
    }
  2. O(log n):变量i的值以对数的方式增长;随着i的值越来越大,i也就离n越近。如:

    java 复制代码
    public void test01(int n){
        int i=1;
        while (i<n){
            i = i * 2;
        }
    }

由以上分析可知,代码的时间复杂度表示为O(log n)

  1. O(n):T(n)与代码的执行次数成正比(代码的执行时间越长,时间复杂度越高)

    java 复制代码
    public void test01(int n){
    	int i = 0;
    	int sum =  0;
    	for(;i<n;i++){
    		sum = sum + i;
    	}
    }

3、空间复杂度:

空间复杂度(Space Complexity)是算法在执行过程中所需的额外空间的量度。它用于评估算法对内存资源的使用情况,包括算法使用的额外内存空间的大小和增长趋势。

  1. O(1):当空间复杂度为 O(1) 时,表示算法使用的额外空间是固定的,与输入规模无关。
java 复制代码
    public void printNumbers(int n) {
    for (int i = 1; i <= n; i++) {
        System.out.println(i);
    }
}
  1. O(n):当空间复杂度为 O(n) 时,表示算法使用的额外空间与输入规模成正比。
java 复制代码
public int[] copyArray(int[] nums) {
    int[] copy = new int[nums.length];
    for (int i = 0; i < nums.length; i++) {
        copy[i] = nums[i];
    }
    return copy;
}
  1. O(n^2) : 当空间复杂度为 O(n^2) 时,表示算法使用的额外空间与输入规模的平方成正比。
java 复制代码
public int[] copyArray(int[] nums) {
    int[] copy = new int[nums.length];
    for (int i = 0; i < nums.length; i++) {
        copy[i] = nums[i];
    }
    return copy;
}
相关推荐
古译汉书3 分钟前
【IoT死磕系列】Day 7:只传8字节怎么控机械臂?学习工业控制 CANopen 的“对象字典”(附企业级源码)
数据结构·stm32·物联网·http
民乐团扒谱机4 分钟前
【硬核解析】网易云听歌/哼歌识曲底层技术:从算法实现到工程落地(附核心公式/伪代码)
算法
Z9fish5 分钟前
sse哈工大C语言编程练习23
c语言·数据结构·算法
ArturiaZ5 分钟前
【day36】
数据结构·c++·算法
山河君9 分钟前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
甲枫叶11 分钟前
【claude热点资讯】Claude Code 更新:手机遥控电脑开发,Remote Control 功能上线
java·人工智能·智能手机·产品经理·ai编程
额,不知道写啥。15 分钟前
P5354 [Ynoi Easy Round 2017] 由乃的 OJ
java·开发语言·算法
代码无bug抓狂人16 分钟前
C语言之单词方阵——深搜(很好的深搜例题)
c语言·开发语言·算法·深度优先
让我上个超影吧24 分钟前
消息队列——RabbitMQ(高级)
java·rabbitmq
im_AMBER29 分钟前
Leetcode 127 删除有序数组中的重复项 | 删除有序数组中的重复项 II
数据结构·学习·算法·leetcode