数据结构与算法之基础概述

article/2025/9/10 3:04:10

目录

  • 数据结构和算法的重要性
  • 数据结构概述
    • 逻辑结构
    • 存储结构
  • 算法概述
    • 如何理解“大O记法”
    • 时间复杂度
    • 空间复杂度

数据结构和算法的重要性

  • 算法是程序的灵魂,优秀的程序可以在海量数据计算时,依然保持高速计算

  • 数据结构和算法的关系

    • 程序 = 数据结构 + 算法
    • 数据结构是算法的基础, 换言之,想要学好算法,需要把数据结构学到位。
  • 数据结构和算法学习大纲
    在这里插入图片描述

数据结构概述

  • 数据结构可以简单的理解为数据与数据之间所存在的一些关系,数据的结构分为数据的存储结构和数据的逻辑结构。

在这里插入图片描述

逻辑结构

  • 集合结构:数据元素同属于一个集合,他们之间是并列关系,无其他的关系;可以理解为中学时期学习的集合,在一个范围之内,有很多的元素,元素间没有什么关系
  • 线性结构:元素之间存在着一对一的关系;可以理解为每个学生对应着一个学号,学号与姓名就是线性结构
  • 树形结构:元素之间存在着一对多的关系,可以简单理解为家庭族谱一样,一代接一代
  • 图形结构:元素之间存在多对多的关系,每一个元素可能对应着多个元素,或被多个元素对应,网状图

存储结构

  • 顺序存储结构:就是将数据进行连续的存储,我们可以将它比喻成学校食堂打饭排队一样,一个接着一个;
  • 链式存储结构:不是按照顺序存储的,后一个进来的数只需要将他的地址告诉前一个节点,前一个节点中就存放了它后面那个数的地址,所以最后一个数的存储地址就是为null;可以将这种结构比喻成商场吃饭叫号,上面的号码比喻成是地址,你可以之后后面的地址是什么,上面的其他内容就是该节点的内容;
  • 区别
    • 顺序存储的特点是查询快,插入或者删除慢
    • 链式存储的特点是查询慢,插入或者删除快

算法概述

  • 同一问题不同解决方法
  • 通过时间和空间复杂度判断算法的优劣
  • 算法没有最好的,只有最合适的,学习算法是为了积累学习思路,掌握学习思路,并不是为了解决某问题去记住某种算法;对于时间复杂度与空间复杂度,现在大多数开发情况下,我们都在使用以空间换时间,耗费更多的内存,来保证拥有更快的速度。
  • 各排序算法复杂度及稳定性
    在这里插入图片描述

如何理解“大O记法”

对于算法进行特别具体的细致分析虽然很好,但在实践中的实际价值有限。对于算法的时间性质和空间性质,最重要的是其数量级和趋势,这些是分析算法效率的主要部分。而计量算法基本操作数量的规模函数中那些常量因子可以忽略不计。例如,可以认为 3n^2 和 100n^2 属于同一个量级,如果两个算法处理同样规模实例的代价分别为这两个函数,就认为它们的效率“差不多”,都为n^2级。

时间复杂度

一个算法花费的时间与算法中语句的执行次数成正比例,哪个算法中语句执行次数多,它花费时间就多。算法中的语句执行次数称为语句频度或时间频度,记为T(n)。n 称为问题的规模,当 n 不断变化时,时间频度T(n)也会不断变化。但有时我们想知道它变化时呈现什么规律。为此,我们引入时间复杂度概念。

一般情况下,算法中基本操作重复执行的次数是问题规模 n 的某个函数,用T(n)表示,若有某个辅助函数f(n),使得当 n 趋近于无究大时,T(n)/f(n)的极限值为不等于零的常数,则称f(n)T(n)同数量级函数。记作T(n)=O(f(n)),称O(f(n))为算法的渐进时间复杂度,简称时间复杂度

有时候,算法中基本操作重复执行的次数还随问题的输入数据集不同而不同,如在冒泡排序中,输入数据有序而无序,结果是不一样的。此时,我们计算平均值。

时间复杂度基本计算规则

  • 基本操作,即只有常数项,认为其时间复杂度为O(1)
  • 顺序结构,时间复杂度按加法进行计算
  • 循环结构,时间复杂度按乘法进行计算
  • 分支结构,时间复杂度取最大值
  • 判断一个算法的效率时,往往只需要关注操作数量的最高次项,其它次要项和常数项可以忽略
  • 在没有特殊说明时,我们所分析的算法的时间复杂度都是指最坏时间复杂度

常用时间复杂度
在这里插入图片描述

  • 注意:经常将log2n(以2为底的对数)简写成logn

常见时间复杂度之间的关系

在这里插入图片描述

  • 所以时间消耗由小到大为O(1) < O(log n) < O(n) < O(nlog n) < O(n^2) < O(2^n) < O(n!) < O(n^n)

案例1

count = 0;				      (1)for(i = 0;i <= n;i++)	  (2)for(j = 0;j <= n;j++) (3)count++;          (4)
  • 语句(1)执行1次
  • 语句(2)执行n次
  • 语句(3)执行n^2次
  • 语句(4)执行n^2次
  • 时间复杂度为T(n) = 1+n+n^2+n^2 = O(n^2)

案例2

a = 1; 						(1)
b = 2;						(2)
for(int i = 1;i <= n;i++) { (3)int s = a + b;			(4)b = a;					(5)a = s;					(6)
}	
  • 语句(1)、(2)执行1次
  • 语句(3)执行n次
  • 语句(4)、(5)、(6)执行n次
  • 时间复杂度为T(n) = 1+1+4n = o(n)

案例3

i = 1;		 (1)
while(i<n) {i = i*2; (2)
}	
  • 语句(1)的频度是1
  • 设语句(2)的频度是f(n),则2f(n)<=n;f(n)<=log2n,取最大值f(n) = log2n
  • 时间复杂度为T(n) = O(log2n)

空间复杂度

  • 算法的空间复杂度计算公式:S(n) = 0( f(n) ),其中 n 为输入规模,f(n)为语句关于 n 所占存储空间的函数

  • 一个算法在计算机存储器上所占用的存储空间,包括三个方面

    • 存储算法本身所占用的存储空间
    • 算法的输入输出数据所占用的存储空间
    • 算法在运行过程中临时占用的存储空间

案例:指定的数组进行反转,并返回反转的内容

解法一:

public static int[] reverse1(int[] arr) {int n = arr.length; //申请4个字节int temp; //申请4个字节for (int start = 0, end = n - 1; start <= end; start++, end--) {temp = arr[start];arr[start] = arr[end];arr[end] = temp;}return arr;
}
  • 空间复杂度为S(n) = 4+4 = O(8) = O(1)

解法二:

public static int[] reverse2(int[] arr) {int n = arr.length; //申请4个字节int[] temp = new int[n]; //申请n*4个字节+数组自身头信息开销24个字节for (int i = n - 1; i >= 0; i--) {temp[n - 1 - i] = arr[i];}return temp;
}
  • 空间复杂度为S(n) = 4+4n+24 = O(n+28) = O(n)

根据大O推导法则,算法一的空间复杂度为0(1),算法二的空间复杂度为0(n),所以从空间占用的角度讲,算法一要优于算法二。

由于java中有内存垃圾回收机制,并且jvm对程序的内存占用也有优化(例如即时编译) , 我们无法精确的评估一个java程序的内存占用情况,但是了解了java的基本内存占用,使我们可以对java程序的内存占用情况进行估算。

由于现在的计算机设备内存一般都比较大,基本上个人计算机都是4G起步,大的可以达到32G ,所以内存占用一般情况下并不是我们算法的瓶颈,普通情况下直接说复杂度,默认为算法的时间复杂度

但是,如果你做的程序是嵌入式开发,尤其是一些传感器设备上的内置程序,由于这些设备的内存很小, 一般为几kb,这个时候对算法的空间复杂度就有要求了,但是一般做java开发的,基本上都是服务器开发, 一般不存在这样的问题。


http://chatgpt.dhexx.cn/article/uE1vIDfg.shtml

相关文章

1.0 JAVA数据结构与算法

学习总结 利用计算机来解决显示世界中的各种实际问题时&#xff0c;首先要将实际问题中的操作对象抽象为能够用计算机表示的数据&#xff0c;为这些数据建立一个数学模型&#xff08;数据的逻辑结构&#xff09;&#xff0c;再面对数据以某种组织形式进行存储&#xff08;数据…

数据结构和算法的区别

1.数据结构 数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 数据结构包括三方面的内容&#xff1a;逻辑结构、存储结构和数据的运算。 1.数据的逻辑结构 数据的逻辑结构分类图如下&#xff1a; 2.数据的存储结构 存储结构是指数据结构在计算机中的表示&#xf…

肝完了,一天掌握数据结构和算法面试题,吊打面试官,一起学习吧

最近有小伙伴面试&#xff0c;对数据结构和算法比较头疼&#xff0c;我整理了一波资料&#xff0c;帮助大家快速掌握数据结构和算法的面试&#xff0c;感觉有用的小伙伴&#xff0c;点赞支持哦&#xff01; 不叨叨&#xff0c;直接上干货。 目录 Q1&#xff1a;数据结构和算…

大一新生先学C语言编程还是先学C语言的数据结构和算法?

大家好&#xff0c;我是辣条。 这是一位粉丝朋友给我的私信&#xff0c;今天就他这个问题好好聊聊。 先学C语言在学数据结构和算法 先说答案建议先学C语言&#xff0c;掌握基本的语法基础后&#xff0c;再学数据结构与算法&#xff0c;C语言编程与数据结构和算法这两个完全是…

【数据结构和算法】如何学习数据结构与算法 ?过来人的建议(一)【方法篇】

&#x1f388; 作者&#xff1a;Linux猿 &#x1f388; 简介&#xff1a;CSDN博客专家&#x1f3c6;&#xff0c;华为云享专家&#x1f3c6;&#xff0c;Linux、C/C、云计算、物联网、面试、刷题、算法尽管咨询我&#xff0c;关注我&#xff0c;有问题私聊&#xff01; &…

数据结构与算法简介

0. 内容说明 最近在自己编写一些小的算法的时候&#xff0c;深感自己的算法过于臃肿。碰巧Datawhale在新的一期组队学习中组织了数据结构与算法的课程学习。于是就参加了&#xff0c;再次感谢Datawhale~~ 首先跟大家分享一下两个自己感觉比较好的学习资料&#xff0c;一个是 …

数据结构和算法知识点整理

Q1&#xff1a;数据结构和算法的知识点整理&#xff1a; 数据结构和算法的需要掌握的知识点&#xff0c;我的好朋友启舰整理的&#xff1a; Q2&#xff1a;链表&#xff0c;队列和栈的区别 链表是一种物理存储单元上非连续的一种数据结构&#xff0c;看名字我们就知道他是一种…

如何学习数据结构和算法

首先掌握常用的、基础的。然后在此基础上往进行扩展学习。 常用的、基础的数据结构和算法有20个。 数据结构&#xff1a;数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie树 算法&#xff1a;递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法…

Java的数据结构和算法

今天我们来简单介绍一下Java的数据结构和算法。 一、数据结构 1、数据结构的分类 2、数据结构的基本功能 二、算法 1、算法是什么 2、算法的特点 一、1、数据结构是计算机组织、存储数据的方式。简单来说就是,数据按指定的规则进行存储,从而得到一个有固定存储格式的数据集…

数据结构与算法——绪论

前言&#xff1a;数据结构与算法是计算机科学与工程的基础&#xff0c;它们的相互关系和作用是程序的本质。凭借一句话获得图灵奖的Pascal之父Nicklaus Wirth把它们表示为 算法数据结构程序 目录&#xff1a; 1、算法与数据结构的重要性①相关定义②为什么要学习算法③数据结构…

【建议收藏】数据结构和算法面试题

数据结构 数据结构分为两大类&#xff0c;线性结构和非线性结构。 线性结构&#xff1a;数组、队列、链表、栈非线性结构&#xff1a;多维数组、树结构、图结构 1.数组 数组是最常用的数据结构&#xff0c;用于存储相同类型的数据&#xff0c;数组的长度也是固定的。 数组…

数据结构和算法:什么是数据结构,什么是算法

文章目录 前言数据结构和算法1.数据结构1.1数据结构的类型2.算法2.1推导大O阶方法常数阶O(1)和线性阶O(n)为什么算法1时间复杂度为O(n)而不是O(1)呢&#xff1f;对数阶O( logn)&#xff1a;平方阶O( n2)&#xff1a; 前言 这几天复习数据结构&#xff0c;在看《大话数据结构》&…

python数据结构和算法

前面系统地学习了python相关的基础知识&#xff0c;接下来&#xff0c;我们将继续学习python的数据结构和算法。 我们知道&#xff0c;程序数据结构算法&#xff0c;那么&#xff0c;什么是数据结构&#xff0c;有什么是算法呢&#xff1f;如何系统的学习数据结构和算法呢&am…

【数据结构和算法】入门初识篇

目录 一、前言 二、数据结构的理解 物理结构和逻辑结构 1.逻辑结构 2. 物理结构 一、前言 我们前面我学了Java的内部类&#xff0c;现在来学习一下数据结构和算法&#xff0c;多科齐下不仅可以 学科交插学习互相帮助&#xff0c;还可以锻炼跳跃性思维。 二、数据结构的…

什么是数据结构和算法

从远古的汇编语言到现代编程语言&#xff0c;计算机编程已经变得更加强大、高效和先进。然而&#xff0c;计算机编程中的数据结构和算法的核心概念和使用并没有改变。从一开始&#xff0c;DSA就一直是计算机编程的核心。 备注: 下文统一使用DSA表示数据结构和算法。 你可能听说…

数据结构与算法——算法

&#x1f60a;数据结构与算法——算法 &#x1f680;什么是算法&#xff1f;&#x1f6a2;算法的特征&#xff08;特性&#xff09; &#x1f680;算法的设计&#xff08;要点&#xff09;&#x1f680;算法效率的度量&#x1f6a2;事后统计法&#x1f6a2;事前分析估算法&…

数据结构与算法

数据结构与算法 1.数据结构的概念 数据结构指的是一组数据的存储结构。 2.算法的概念 算法是指操作数据的一组方法 3.二者的关系 数据结构是为算法服务的&#xff0c;而算法要作用在特定的数据结构上。 4.最常用的数据结构预算法 数据结构&#xff1a;数组、链表、栈、队列、散…

数据结构与算法学习笔记

本文是王争老师的《算法与数据结构之美》的学习笔记&#xff0c;详细内容请看王争的专栏 。有不懂的地方指出来&#xff0c;我做修改。 数据结构与算法思维导图 数据结构指的是“一组数据的存储结构”&#xff0c;算法指的是“操作数据的一组方法”。 数据结构是为算法服务的&a…

数据结构与算法(总结)

总结&#xff1a; 一、数据结构&#xff08;Data Structure&#xff09; 是数据的组织结构&#xff0c;用来组织、存储数据。算法&#xff08;Algorithm&#xff09; 就是解决问题的方法或者过程。 二、数据结构分为逻辑结构和物理结构。逻辑结构分为集合结构、线性结构、树形结…

Minio 分布式集群部署

文章目录 一、分布式存储可靠性常用方法1. 概述2. 冗余3. 校验 二、分布式Minio优势2.1. 数据保护2.2. 高可用2.3.一致性 三、运行分布式Minio3.1. 启动方案简述3.2. 案例说明3.3. 制作分布式启动脚本3.4. 制作伪分布式启动脚本3.5. 登录minio 四、分布式Minio负载均衡4.1. ngi…