C语言复杂度(个人笔记)

时间复杂度主要衡量一个算法的运行快慢.

空间复杂度主要衡量一个算法运行所需要的额外空间.

时间复杂度

算法中的基本操作的执行次数,为算法的时间复杂度.

只需要大概执行次数,我们使用大O的渐进表示法。(看谁对数学表达式的影响最大)

空间复杂度

是对一个算法在运行过程中临时占用存储空间大小的量度 。

注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显式申请的额外空间来确定。

笔试题

消失的数字

c 复制代码
//解法一:通过异或运算符实现(两个相同的数异或等于0)
int missingNumber(int* nums, int numsSize)
{
    int ret=0;
    int i=0;
    for(i=0;i<numsSize;i++)
    {
        ret^=nums[i];
    }
    for(i=0;i<numsSize+1;i++)
    {
        ret^=i;
    }
    return ret;
}
//解法二:通过数学方法实现(等差数列)
int missingNumber(int* nums, int numsSize)
{
    int ret=0;
    int i=0;
    for(i=0;i<numsSize+1;i++)
    {
        ret+=i;
    }
    for(i=0;i<numsSize;i++)
    {
        ret-=nums[i];
    }
    return ret;
}

旋转数组

c 复制代码
//三逆置解决
void reverse(int* arr,int left,int right)
{
    while(left<right)
    {
        int tmp=arr[left];
        arr[left]=arr[right];
        arr[right]=tmp;
        left++;
        right--;
    }
}
//另外开辟一块空间,进行拷贝
void rotate(int* nums, int numsSize, int k)
{
    if(k>numsSize)
    {
        k%=numsSize;
    }
    reverse(nums,0,numsSize-k-1);
    reverse(nums,numsSize-k,numsSize-1);
    reverse(nums,0,numsSize-1);
}
相关推荐
wusixuan1310042 小时前
最大闭合子图学习笔记 / P2805 [NOI2009] 植物大战僵尸
笔记·学习·算法·最大闭合子图
moxiaoran57532 小时前
uni-app项目实战笔记5--使用grid进行定位布局
笔记·uni-app
轩宇^_^2 小时前
C语言结构体与联合体详解
c语言·开发语言
羊小猪~~2 小时前
数据库学习笔记(十五)--变量与定义条件与处理程序
数据库·人工智能·笔记·后端·sql·学习·mysql
霸王蟹2 小时前
带你手写React中的useReducer函数。(底层实现)
前端·javascript·笔记·学习·react.js·typescript·前端框架
Humbunklung2 小时前
分布假设学习笔记
笔记·深度学习·学习
嵌入式@秋刀鱼3 小时前
《 第三章-招式初成》 C++修炼生涯笔记(基础篇)程序流程结构
linux·开发语言·数据结构·c++·笔记·visual studio code
HaiQinyanAN3 小时前
【学习笔记】重载和重写的注意事项
c++·笔记·学习
梦境虽美,却不长3 小时前
C语言 学习 文件操作(开关,读写,定位,大小)操作 2025年6月8日12:19:24
c语言·开发语言·学习
@老蝴12 小时前
C语言 — 通讯录模拟实现
c语言·开发语言·算法