码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构和算法


    16. 数据结构和算法

    文章目录

      • 16. 数据结构和算法
        • 16.1 作用
        • 16.2 算法
          • 16.2.1 五大特性
          • 16.2.2 时间效率衡量
        • 16.3 时间复杂度
        • 16.4 空间复杂度
        • 16.5 数据结构
          • 16.5.1 作用
          • 16.5.2 分类

    16.1 作用

    大大提升程序的性能

    面试高频考点

    16.2 算法

    为了实现业务目的的各种方法和思路

    算法是独立存在的一种解决问题的方法和思想

    16.2.1 五大特性

    • 输入

      • 0个或多个输入
    • 输出

      • 1和或多个输出
    • 有穷性

      • 算法在有限的步骤后会自动结束而不会无限循环
    • 确定性

      • 每一步都有确定的含义,不会出现二义性
    • 可行性

      • 每一步都是可行的

    16.2.2 时间效率衡量

    • 时间效率 T = 操作步骤数量 * 操作步骤执行时间

    16.3 时间复杂度

    • 表示一个算法随着问题规模不断变化的最主要趋势

    大O记法 T(n) = O(n3) 最高次项

    • 计算规则

      ① 基本操作,时间复杂度为O(1)

      ② 顺序结构,加法

      ③ 循环结构,乘法

      ④ 分支结构,取最大值

      ⑤ 关注最高次项

      ⑥ 没有特殊说明时,分析的时间复杂度都是指最坏时间复杂度

    • 最优最坏

      • 算法完成工作最少需要多少基本操作 → 最优时间复杂度
      • 算法完成工作平均需要多少基本操作 → 平均时间复杂度
      • 算法完成工作最多需要多少基本操作 → 最坏时间复杂度
    • 常见时间复杂度

      • 在这里插入图片描述

      • 在这里插入图片描述

    16.4 空间复杂度

    • S(n) 对一个算法在运行过程中临时占用存储空间大小的度量

    16.5 数据结构

    存储、组织数据的方式。指相互之间存在一种或多种特定关系的数据元素的集合

    16.5.1 作用

    • 相同的数据用不同的数据结构存储,运行、存储效率是不同的

    16.5.2 分类

    • 线性结构

      • 各个节点具有线性关系

      • 特点

        • 非空集
        • 所有结点都最多只有一个直接前趋结点和一个直接后继结点
      • 栈、队列等

    • 非线性结构

      • 各个结点具有多个对应关系

      • 特点

        • 非空集
        • 一个结点可能有多个直接前趋结点和多个直接后继结点
      • 树、图等

    算法是为了解决实际问题而设计的,数据结构是算法需要处理问题的载体

  • 相关阅读:
    java设计模式---策略模式
    RabbitMQ 死信队列
    在Linux系统上用nmap扫描SSL漏洞的方法
    【每日一题】522. 最长特殊序列 II
    软件测试面试屡战屡败?——我整理了一份超全面试题详解
    (算法设计与分析)第三章动态规划-第一节1:动态规划基本思想、框架
    用Python分析《三国演义》中的人物关系网
    Redis持久化RDB/AOF
    实践笔记-docker安装及配置镜像源
    Linux多线程之线程控制
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/126118815
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号