数据结构(一) 绪论

一. 时间复杂度:

(1)定义:

时间复杂度是衡量算法执行时间随输入规模(通常用n表示)增长的变化趋势的指标,时间复杂度用O符号表示

用于描述算法在最坏情况下或平均情况下的时间需求

时间复杂度关注的是操作次数的增长率,而非具体执行时间

常见的时间复杂度由小到大依次为:

O(1) < O(log2n) < O(n) < O(nlog2n) < O(n²) < O(n³) < ...... < O(2^n) < O(n!)

Example:

1.若一个算法需要执行 3n² + 2n + 1 次操作,其时间复杂度为O(n²),因为最高阶项n²主导增长趋势,常数系数和低阶项容易被忽略

  1. O(1): 访问数组中的某个元素

  2. O(n): 遍历数组求和

cpp 复制代码
int Sum_Array(int num[]){
    int sum=0;
    for(int i=0; i<N; i++){
        sum += num[i];
    }
    return sum;
}

输入规模为n, for循环执行n次,时间复杂度为O(n)

4.O(n²) : 冒泡排序

cpp 复制代码
void bubbleSort(int arr[], int n){
    for(int i=0;i<n-1;i++){
        for(int j=0;j<n-i-1;j++){
            if(arr[j]>arr[j+1]){
                int temp=arr[j];
                arr[j]=arr[j+1];
                arr[j+1]=temp;
            }
        }
    }
}

for循环执行次数为n(n-1)/2,时间复杂度为O(n²)

(2)如何判断时间复杂度:

1.逐层分析代码:

单层循环 -> O(n)

双层循环 -> O(n²)

分治算法(归并排序) -> O(nlogn)

2.注意循环终止条件:

若循环变量每次乘以2(如 i *= 2),循环次数为 O(log⁡n)

3.递归:

递归调用次数和输入规模有关,斐波那契数列递归的时间复杂度为O(2^n)

二. 空间复杂度:

(1)定义:

空间复杂度衡量算法运行过程中临时占用的存储空间大小,同样用大 OO 符号表示。

包括算法显式内存(变量和数据结构)和隐式占用栈空间(递归调用)

Example:

1.若算法需要额外创建一个长度为n的数组,则空间复杂度为O(n)

2.O(1): 交换两个变量的值

cpp 复制代码
void swap(int* a, int* b){
    int temp = *a;    // 仅使用一个临时变量
    *a = *b;
    *b = temp;
}

3.O(n) : 归并排序

4.递归栈空间O(n): 递归计算阶乘

cpp 复制代码
double factorial(int n){
    double ans = 1;
    if(n == 0 || n == 1) return 1;
    else return n * factorial(n);    // 递归深度为n
}

递归调用栈的最大深度为 nn,空间复杂度为 O(n)

(2)如何判断空间复杂度:

1.分析代码:

若创建与输入规模相同的数组 -> O(n)

若仅使用固定数量的变量 -> O(1)

2.递归调用的深度:

斐波那契递归的空间复杂度为 O(n) (最大调用深度为 n)

快速排序的平均递归深度为 O(log⁡n), 空间复杂度为 O(log⁡n)

3.动态内存分配

相关推荐
刘马想放假12 小时前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠1 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦8 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠9 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾9 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8219 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q9 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒10 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记10 天前
单项不带头不循环链表
数据结构·链表
小糯米60110 天前
JS 数组
数据结构·算法·排序算法