算法的复杂度【数据结构】

这篇具有很好参考价值的文章主要介绍了算法的复杂度【数据结构】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、时间复杂度

  • 算法在编写成可执行程序后,运行时需要耗费时间资源和空间(内存)资源,因此衡量一个算法的好坏一般是从时间和空间两个维度来衡量的,即时间复杂度空间复杂度
  • 时间复杂度主要衡量一个算法的运行快慢,而空间复杂度主要衡量一个算法运行所需要的额外空间。

(1)时间复杂度只保留最高阶项

算法的复杂度【数据结构】

(2)同级别的未知数不能省略

算法的复杂度【数据结构】

(3)常数次的时间复杂度为O(1)

算法的复杂度【数据结构】

(4)常数×未知数,常数可以省略

算法的复杂度【数据结构】

(5)关注算法的最坏运行情况

算法的复杂度【数据结构】

(6)冒泡排序O(N^2)

算法的复杂度【数据结构】

(7)二分查找O(log2(N))

算法的复杂度【数据结构】

(8)递归调用对比

算法的复杂度【数据结构】

(9)斐波那契递归O(2^N)

算法的复杂度【数据结构】

(10)Leetcode题目链接:消失的数字

  • 方法1:排序,依次查找,如果下一个数不是上一个数+1,那么上一个数+1就是消失的数字 【O(N*log2(N))】
  • 方法2:异或法 【O(N)】
int missingNumber(int* nums, int numsSize)
{
     int x=0;
     for(int i=0;i<numsSize;i++)
     {
         x=x^nums[i];
     }
     for(int i=0;i<numsSize+1;i++)
     {
         x=x^i;
     }
     return x;
}
  • 方法3:0~N等差数列求和,再减去数组中已有的数 【O(N)】
int missingNumber(int* nums, int numsSize)
{
    int x = (0 + numsSize) * (numsSize + 1) / 2; //等差数列求和
    for (int i = 0; i < numsSize; i++)
    {
        x = x - nums[i];
    }
    return x; //缺失的数=等差数列的和-数组中已有的数
}

2、空间复杂度

  • 空间复杂度也是一个数学表达式,是对一个算法在运行过程中临时占用额外存储空间大小的量度
  • 空间复杂度不是程序占用了多少bytes的空间,空间复杂度算的是变量的个数
  • 注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显式申请的额外空间来确定

(1)冒泡排序O(1)

(2)斐波那契递归O(N)

算法的复杂度【数据结构】

(3)阶乘递归O(N)

算法的复杂度【数据结构】

(4)Leetcode题目链接:轮转数组

算法的复杂度【数据结构】文章来源地址https://www.toymoban.com/news/detail-475494.html

void swap(int* a, int* b)
{
    int temp = *a;
    *a = *b;
    *b = temp;
}

void reverse(int arr[], int start, int end)
{
    while (start < end)
    {
        swap(&arr[start], &arr[end]);
        start++;
        end--;
    }
}

void rotate(int* nums, int numsSize, int k)
{
    //方法一:
    // int temp=0;
    // for(int i=0;i<k;i++)
    // {
    //     temp=nums [numsSize-1];
    //     for(int j=numsSize-1;j>0;j--)
    //     {
    //         nums[j]=nums[j-1];
    //     }
    //     nums[0]=temp;
    // }

    //方法二:
    // int newArr[numsSize];
    // for (int i = 0; i < numsSize; i++)
    // {
    //     newArr[(i + k) % numsSize] = nums[i];
    // }
    // for (int i = 0; i < numsSize; i++)
    // {
    //     nums[i] = newArr[i];
    // }

    //方法三:
    k = k % numsSize; //k可能比数组大,在这种情况下,向右移动整个数组长度后就回到原来的位置,k%numsSize就是去掉每次回到原来位置的步数,获得能够产生相同结果的最少步数
    reverse(nums, 0, numsSize - 1);
    reverse(nums, 0, k - 1);
    reverse(nums, k, numsSize - 1);
}

到了这里,关于算法的复杂度【数据结构】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构与算法—时间复杂度和空间复杂度

    目录 1、什么是数据结构? 2、什么是算法? 3、算法的复杂度 4、时间复杂度 (1) 时间复杂度的概念:  (2) 大O的渐进表示法:  六个例题: (3) 时间复杂度对比:  三个例题:  OJ题分析时间复杂度 5、空间复杂度 (1)常见复杂度对比  (2)OJ题分析空间复杂度 小结 数据结构 (D

    2024年02月07日
    浏览(39)
  • 数据结构 | 算法的时间复杂度和空间复杂度【详解】

    数据结构(Data Structure)是计算机存储、组织数据的方式,指相互之间存在一种或多种特定关系的数据元素的集合。 算法(Algorithm):就是定义良好的计算过程,他取一个或一组的值为输入,并产生出一个或一组值作为输出。简单来说算法就是一系列的计算步骤,用来将输入数据转

    2024年02月08日
    浏览(35)
  • 【数据结构与算法篇】时间复杂度与空间复杂度

       目录 一、数据结构和算法 1.什么是数据结构?  2.什么是算法? 3.数据结构和算法的重要性 二、算法的时间复杂度和空间复杂度 1.算法效率 2.算法的复杂度 3.复杂度在校招中的考察 4.时间复杂度 5.空间复杂度  6.常见复杂度对比 7.复杂度的OJ练习   👻内容专栏:《数据结

    2023年04月24日
    浏览(48)
  • 【数据结构与算法】1.时间复杂度和空间复杂度

    📚博客主页:爱敲代码的小杨. ✨专栏:《Java SE语法》 ❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️ 🙏小杨水平有限,欢迎各位大佬指点,相互学习进步! 算法效率分为两种:第一种是时间效率;第二种是空间效率。时间效率又称为时间

    2024年01月20日
    浏览(35)
  • 学习数据结构:算法的时间复杂度和空间复杂度

    衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的,即时间复杂度和空间复杂度。 时间复杂度主要衡量一个算法的运行快慢,而空间复杂度主要衡量一个算法运行所需要的额外空间。 算法的时间复杂度 算法中的基本操作的执行次数,为算法的时间复杂度。 算法的

    2024年04月11日
    浏览(33)
  • 【数据结构初阶】算法的时间复杂度和空间复杂度

    1.1 如何衡量一个算法的好坏 如何衡量一个算法的好坏呢? 比如对于以下斐波那契数列: 斐波那契数列的递归实现方式非常简洁,但简洁一定好吗?那该如何衡量其好与坏呢? 1.2 算法的复杂度 算法在编写成可执行程序后,运行时需要耗费时间资源和空间(内存)资源 。因此

    2024年02月08日
    浏览(37)
  • 从头开始:数据结构和算法入门(时间复杂度、空间复杂度)

        目录 文章目录 前言 1.算法效率 1.1 如何衡量一个算法的好坏 1.2 算法的复杂度 2.时间复杂度  2.1 时间复杂度的概念 2.2 大O的渐进表示法 2.3常见时间复杂度计算 3.空间复杂度 4.常见复杂度对比 总结 前言         C语言的学习篇已经结束,今天开启新的篇章——数据结构

    2024年02月14日
    浏览(39)
  • 【数据结构与算法篇】之时间复杂度与空间复杂度

    ❤️博客主页: 小镇敲码人 🍏 欢迎关注:👍点赞 👂🏽留言 😍收藏 🌞友友们暑假快乐,好久不见呀!!!💖💖💖 🍉 有人曾经问过我这样一个问题,“人终其一身,执着追求的东西究竟是什么?”我是这样回答的,”我们终其一生都在寻找着那个和我们灵魂极其契合

    2024年02月12日
    浏览(33)
  • 算法之时间复杂度---数据结构

    目录 前言: 1.时间复杂度 1.1时间复杂度的理解 1.2规模与基本操作执行次数 1.3大O渐进表示法 1.4计算基本操作的次数 2.常见的时间复杂度及其优劣比较 ❤博主CSDN:啊苏要学习     ▶专栏分类:数据结构◀   学习数据结构是一件有趣的事情,希望读者能在我的博文切实感受到

    2024年02月05日
    浏览(46)
  • 数据结构——算法的时间复杂度

    🌇个人主页:_麦麦_ 📚今日名言: 生命中曾经有过的所有灿烂,都终究需要用寂寞来偿还。 ——《百年孤独》 目录 一、前言 二、正文         1.算法效率                 1.1如何衡量一个算法的好坏                 1.2算法的复杂度         2. 时间复杂度      

    2024年02月03日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包