蓝桥备赛(11)- 数据结构、算法与STL

一、数据结构

1.1 什么是数据结构?

在计算机科学中,数据结构是一种   数据组织、管理和存储的格式。它是相互之间存在一种
或多种特定关系的数据元素的集合
--->  通俗点,数据结构就是数据的组织形式 , 研究数据是用什么方式存储在存储在g'v计算机中的

1.2 为什么会有数据结构?

1) 随着计算机的发展和应用范围的拓展,计算机需要处理的数据量越来越大,数据类型越来越多,数据之间的关系也越来越复杂

2)这就要求⼈们对计算机加工处理的数据进行系列的研究,即研究数据的特性、数据之间存在的关系,以及如何有效的组织、管理存储数据, 从而提高计算机处理数据的效率。

1.3 数据结构的三要素

1.3.1 逻辑结构

数据结构:数据中各元素之间的逻辑关系

只关心数据中各个元素之间的关系 , 并不关心数据在内存中存储的

1)集合: 所有数据只是放在一个集合中 , 彼此之间再没有其他联系

2)线性结构:数据之间只存在一对一的关系

3)树:数据之间是一对多的关系

4)图结构:数据之间存在多对多的关系

1.3.2 存储结构

存储结构又称 物理结构 , 但是存储二字 更能理解 ,后续我们统称为数据结构。

存储结构 顾名思义 , 就是如何把数据在计算机中存储。

1) 顺序存储:把逻辑上相邻的元素存储在  物理上也相邻的存储单元中  ---> 数组(逻辑、物理上都是连续的)

2)链式存储:逻辑上两个元素相邻 , 但是物理结构上不一定相邻 

 

1.3.3 数据的运算

数据的运算,(针对数据的各种操作) , 包括数据结构的实现 , 以及基于数据结构上的各种操作。

--->   意思是 , 我们已经知道了一堆数据中  各个元素之间的关系 , 也知道这堆数据应该在内存中如何存储 。

----> 那么接下来就是写代码 , 完成我们的需求

二、算法

2.1 什么是算法?

简单来说 --->  算法就是一系列的步骤  , 用来将输入数据转化为输出结果(用来解决问题)

 

2.2 算法好坏的度量

算法设计好后,根据算法的设计原理,只要问题规模确定,算法中 基本语句执行次数 和 需求资源个数 基本也就确定了。
比如求 1 + 2 + 3 + ... + ( n − 1) + n ,可以设计三种算法:
算法A : 需要 开辟大小为N 的空间
const int N = 1e5 + 10;
int a[N];
int sum(int n)
{
 // 先把 1 ~ n 存起来
 for(int i = 1; i <= n; i++)
 {
     a[i] = i;
 }
 
 // 循环逐个数字相加
 int ret = 0;
 for(int i = 1; i <= n; i++)
 {
     ret += a[i];
 }
 return ret;
}

算法B:不需要开辟空间 , 直接求和;

int sum(int n)
{
 // 循环逐个数字相加
 int ret = 0;
 for (int i = 1; i <= n; i++) 
 {
     ret += i;
 }
 return ret;
}

算法执行所需资源的个数与问题的规模 n 有关 。因此可以根据算法执行过程中对空间的消耗来衡量算法的好坏 , 这就是空间复杂度 。

算法C:需要循环 n 次 , ret += n 语句会执行 n 次 , 而且随着问题规模的增长 , 执行次数也会增长 。

int sum(int n)
{
 int ret = 0;
 // 循环逐个数字相加
 for (int i = 1; i <= n; i++) 
 {
     ret += i;
 }
 return ret;
}

 算法D : 不管问题规模 n 为多少 , ( 1 + n ) * n / 2 语句只会执行1次。

int sum(int n)
{
 // 利⽤求和公式
 return (1 + n) * n / 2;
}

算法中基本语句总的执行次数与问题规模 n 有关 。因此可以根据算法执行过程中 , 所有语句被执行的次数之和来衡量算法的好坏这就是时间复杂度 。  

综上所述 , 时间和空间的消耗情况就是我们度量一个算法好坏的标准 , 也就是时间复杂度和空间复杂度 。 

2.3 时间复杂度

在计算机中 , 算法的时间复杂度是一个函数式 T(N)他定量描述了该算法的运行时间 。这个T(N)函数式计算了程序中语句的执行次数 。

计算一下 fun 中++count 语句总共执行了多少次 。

void fun(int N) 
{ 
 int count = 0; 
 for(int i = 0; i < N; i++) 
 { 
     for(int j = 0; j < N; j++) 
     { 
         ++count; // 执⾏次数是 n*n,也就是 n^2
     } 
 } 
 for(int k = 0; k < 2 * N; k++) 
 {
     ++count; // 执⾏次数是 2*n
 } 
 
 int M = 10; 
 while(M--) 
 { 
     ++count; // 执⾏次数 10
 } 
}

 

2.3.1 大O表示法

因此,在计算时间复杂度的时候,一 般会把中对结果影响不大的项忽略掉 ,这种表示时间复杂度的方式称 为大 O 渐进时间复杂度 - 粗略的估计方式 只看影响时间开销最大的⼀项。

2.3.2 最优、平均和最差时间复杂度

案例:在 n 个整形元素数组中,检测 x 是否存在,若存在返回其在数组中的下标,否则返回 −1
int find (int a[], int n, int x)
{
 for (int i = 0; i < n; i++)
 {
     if (a[i] == x) 
     return i;
 }
     return -1;
}

1) 在查找过程中,  x 与数组中元素依次比较, 因此总的比较次数就是该算法的时间复杂度。
--->   若待查找元素 x 21 ,只需要比较 1 次,为算法的最优(好)情况
--->   若带查找元素 x 17 ,或者是不存在的元素,需要比较 n 次,为算法的最坏(差)情况
--->   所有情况的比较 次数之和,除以总情况,为算法的平均情况。

无论是在竞赛还是工程中,算法的时间复杂度⼀般为最差情况。 因为最差情况是人对⼀件事情所能承受的底线 因此 find 算法的时间复杂度为 O(n )

 

2.3.3 时间复杂度计算案例

案例一:

案例二:

基本语句 ++count 关于问题规模 n 总执行次数的数学表达式为: f ( n ) = 1000
不论 n 如何变化, ++count 总的执行次数都是 1000 故时间复杂度为: O(1)

 案例三:

void func3(int m, int n)
{
     for (int i = 0; i < m; i++)
     {
     printf("hello\n");
     }
 
     for (int i = 0; i < n; i++)
     {
     printf("hello\n");
     }
}
基本语句 printf("") 总的执行次数为 f(m, n) = m + n
m 和 n 的变化都是影响基本语句执行次数, 即m  和 n 都是问题规模, 故时间复杂度为
O ( m + n ) 或者也可以表示为 O(max(m,n))  

案例四:

 基本语句 printf("") 总的执行次数为 f(m, n) = m x n

m 和 n 的变化都是影响基本语句执行次数, 即m  和 n 都是问题规模, 故时间复杂度为
O ( m x   n )

案例5:

void func5(int n)
{
     int cnt = 1;
     while (cnt < n)
     {
     cnt *= 2;
     }
}

案例六:

递归算法时间复杂度求解方式为,单次递归时间 × 总的递归次数。
注意,这里只是简易的估算方式。递归算法的时间复杂度严谨的计算方法是 利用主定理 (Master Theorem)来求得递归算法的时间复杂度
                                               O( n )

 

2.4 空间复杂度

在算法竞赛中,空间复杂度就是整个程序在解决这个问题时, ⼀共使用了多少空间。相比较于时间复杂度,空间复杂度就没那么受关注,因为多数情况下题目所给的内存限制是非常宽裕的。 但是,这并不表明可以肆无忌惮的使用空间,一旦超出给定的限制,程序也是不会通过的。 - MLE

案例一:冒泡排序 

#include <iostream>
using namespace std;

const int N = 20;
int arr[N];

int main()
 {
	int n = 0;
	cin >> n;
	int i = 0;
 	//输入 
	 for(i=0; i < n; i++)
	 	cin >> arr[i];
	 //排序
	 for(i = 0; i < n-1; i++)
	 {
		 int j = 0;
		 for(j = 0; j <= n-1-i; j++)
		 {
			if(arr[j] < arr[j+1])
			 {
				 int tmp = arr[j];
				 arr[j] = arr[j+1];
				 arr[j+1] = tmp; 
			 }
		 }
	 } 
	 //输出
	for(i=0; i < n; i++)
	{
		cout << arr[i] << endl;
	}
 	return 0;
 }

案例二:递归求阶乘

 

2.5 常见复杂度的增长对比

 

2.6 算法中的时间和空间限制

1. 信息学竞赛中,C++ 通常设定 1 到 2 秒的时间限制,运行次数在 10^7 ⾄ 10^8 之间。
2.空间限制在128MB 或 256MB ,可以开⼀个3 x 10 ^7 大小的int  类型数组,或者5000x5000大小的二维数组,⼀般情况下都是够⽤的。
各种数据量下,可选用的算法的时间复杂度:

三、STL

3.1 C++标准库

1) C++标准是C++编程语言的规范,由国际标准化组织(ISO)制定。C++标准的发展历程可以追溯到 1998年,当时ISO/IEC 14882:1998标准被发布,这是第⼀个C++标准,常被称为C++98。随后,C++标准经历了多次更新和修订,包括C++03(2003年)、C++11(2011年)、C++14(2014年)、C++17(2017年)以及 C++20。
2)最新的C++标准是C++23,于2023年发布,引入了许多新特性, 但目前完整的编译器较少。
3)每⼀个版本的 C++ 标准不仅规定了 C++ 的语法、语言特性,还规定了⼀套 C++ 内置库的实现规范,这个库便是 C++ 标准库。C++ 标准库中包含大量常用代码的实现,如输入输出、基本数据结构、内存管理、多线程支持等。
4)我们可以这样简单的理解,C++ 给我们提供了一大堆的代码,这些代码里面包含特别多已经实现好的   数据结构 和 算法  因此,在做题的时候,如果涉及的数据结构和算法 C++ 标准库已经帮我们实现好 了,那么就可以直接使用,避免重复造轮子 --- sort / min / max / swap
1) 造轮子指的是重复发明已有的算法,或者重复编写现成优化过的代码。
2)造轮子通常耗时好力,同时效果还没有别人好。但若是为了学习或者练习,造轮子则是必要的。
因此,学好 C++ 标准库能极大的提高编程效率。

3.2 什么是STL?

STL 即标准模板库(Standard Template Library),是 C++ 标准库的一部分, 里面包含了⼀些模板化的通过用的数据结构和算法 。由于其模板化的特点,它能够兼容自定义的数据类型,避免大量的造轮子工作。
NOI 和 ICPC 赛事都支持 STL 库的使用,当然, 蓝桥杯也是支持的 。因此,⼀定要学习 STL 的使用, 能够极大的提高编写代码的效率。

3.3 怎么学习STL?

模范使用!!! STL 的实现涉及比较⾼深的 C++ 知识, 比如类、模板、容器适配器等 。如果想 搞清楚背后的原理,就必须要学会这些知识。但是这些知识在竞赛中是用不到的,如果深究,会浪费
大量无用的时间。因此,目前先把重点放在如何使用上

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/982697.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VsCode + EIDE + OpenOCD + STM32(野火DAP) 开发环境配置

VsCode EIDE OpenOCD STM32(野火DAP) 开发环境配置 接受了新时代编辑器的我&#xff0c;实在受不了Keil的上古编辑页面&#xff0c;周树人说过&#xff1a;由奢入俭难&#xff0c;下面我们一起折腾一下开源软件Vscode&#xff0c; 用以开发51和STM32&#xff0c;有错误之处&…

esp32驱动带字库芯片TFT屏幕

前言 学习esp32单片机开发&#xff0c;前段时间在网上买了一块2.0寸TFT屏幕。 长这个样子&#xff0c;这个屏幕带汉字字库的硬件模块。我仔细看了一下这个字库模块上面写的字是25Q32FVSIG 1336 文档 卖家也发来了开发文档&#xff0c;是个doc文档&#xff0c;张这个样子。 开…

短分享-Flink图构建

一、背景 通过简单的书写map、union、keyby等代码&#xff0c;Flink便能构建起一个庞大的分布式计算任务&#xff0c;Flink如何实现的这个酷炫功能呢&#xff1f;我们本次分享Flink做的第一步&#xff0c;将代码解析构建成图 源码基于Flink 2.10&#xff0c;书籍参考《Flink核…

在 ASP.NET Core 中启用 Brotli 和 Gzip 响应压缩

在本文中&#xff0c;我们将探讨如何在 ASP.NET Core 应用程序中启用响应压缩&#xff0c;重点介绍 Brotli 和 Gzip 算法以及如何验证压缩是否有效。 什么是响应压缩&#xff1f; 响应压缩通过使用Brotli 或 Gzip等算法来最小化 HTTP 响应的大小。这些算法在传输文本资产&#…

调研:如何实现智能分析助手(Agent)(AutoCoder、FastGPT、AutoGen、DataCopilot)

文章目录 调研&#xff1a;如何实现智能分析助手&#xff08;Agent&#xff09;&#xff08;AutoCoder、FastGPT、AutoGen、DataCopilot&#xff09;一、交互流程二、数据流程三、架构分类四、开源产品4.1 AutoCoder&#xff08;知识库变体&#xff09;4.2 FastGPT&#xff08;…

由麻省理工学院计算机科学与人工智能实验室等机构创建低成本、高效率的物理驱动数据生成框架,助力接触丰富的机器人操作任务

2025-02-28&#xff0c;由麻省理工学院计算机科学与人工智能实验室&#xff08;CSAIL&#xff09;和机器人与人工智能研究所的研究团队创建了一种低成本的数据生成框架&#xff0c;通过结合物理模拟、人类演示和基于模型的规划&#xff0c;高效生成大规模、高质量的接触丰富型机…

Oracle OCP认证考试考点详解083系列01

题记&#xff1a; 本系列主要讲解Oracle OCP认证考试考点&#xff08;题目&#xff09;&#xff0c;适用于19C/21C,跟着学OCP考试必过。 1. 第1题&#xff1a; 题目 解析及答案&#xff1a; 关于自动工作量存储库&#xff08;AWR&#xff09;快照&#xff0c;以下哪三个选项…

perl初试

我手头有一个脚本&#xff0c;用于从blastp序列比对的结果文件中&#xff0c;进行文本处理&#xff0c; 获取序列比对最优的hit记录 #!/usr/bin/perl -w use strict;my ($blast_out) ARGV; my $usage "This script is to get the best hit from blast output file wit…

Nginx1.19.2不适配OPENSSL3.0问题

Nginx 1.19.2 是较老的版本&#xff0c;而 Nginx 1.21 版本已经适配 OpenSSL 3.0&#xff0c;所以建议 升级 Nginx 到 1.25.0 或更高版本&#xff1a; wget http://nginx.org/download/nginx-1.25.0.tar.gz tar -xzf nginx-1.25.0.tar.gz cd nginx-1.25.0 ./configure --prefix…

MySQL复合查询——通过案例讲解每个指令

0.准备工作 在开始之前可以先准备好相同的数据库 方法一&#xff1a;直接在MySQL创建相应的数据库和表 第一步&#xff1a;创建数据库并进入数据库 create database soctt_data; use soctt_data; 第二步&#xff1a;创建部门信息表 DROP TABLE IF EXISTS dept; CREATE TABL…

Kubernetes全解析:从容器编排到云原生霸主

前言 在数字化转型浪潮中&#xff0c;云原生技术已成为企业构建敏捷、弹性基础设施的核心驱动力。作为容器编排领域的“操作系统”&#xff0c;Kubernetes&#xff08;K8s&#xff09;凭借其自动化部署、弹性伸缩和跨环境一致性等能力&#xff0c;正重新定义现代应用的运维范式…

我的两个医学数据分析技术思路

我的两个医学数据分析技术思路 从临床上获得的或者公共数据库数据这种属于观察性研究&#xff0c;是对临床诊疗过程中自然产生的数据进行分析而获得疾病发生发展的规律等研究成果。再细分&#xff0c;可以分为独立危险因素鉴定和预测模型构建两种。 独立危险因素鉴定是一直以…

图像滑块对比功能的开发记录

背景介绍 最近&#xff0c;公司需要开发一款在线图像压缩工具&#xff0c;其中的一个关键功能是让用户直观地比较压缩前后的图像效果。因此&#xff0c;我们设计了一个对比组件&#xff0c;它允许用户通过拖动滑块&#xff0c;动态调整两张图像的显示区域&#xff0c;从而清晰…

迷你世界脚本UI五子棋小游戏

wzq_jm "7477124677881080183-22855"--界面id wzq_jmjxh "7477124677881080183-22855_"--界面加下划线 wzq_tc "7477124677881080183-22855_262"--退出按钮id wzq_hdlt1 "7477124677881080183-22855_267"--互动聊天按钮 快点吧&a…

大模型理论基础介绍

大模型理论基础 {docsify-ignore-all} 项目简介 本项目旨在作为一个大规模预训练语言模型的教程&#xff0c;从数据准备、模型构建、训练策略到模型评估与改进&#xff0c;以及模型在安全、隐私、环境和法律道德方面的方面来提供开源知识。 项目将以斯坦福大学大规模语言模型课…

【Spring Boot 应用开发】-04-02 自动配置-数据源-手撸一个最简持久层工具类

设计概述 有时候我们不需要太重的持久层&#xff0c;就像要一个最简的、轻量的持久层&#xff0c;便于维护和扩展&#xff0c;代码掌握在自己手里&#xff0c;那么我们可以基于springboot的自动配置&#xff0c;快速的构建一个自己的持久层轻量框架&#xff0c;不说废话&#…

MicroServer Gen8再玩之三 OCP万兆光口+12G阵列卡

前一段时间&#xff0c;做了一片双OCP的合成转接卡&#xff0c;在GEN8上用了起来&#xff0c;有些小伙伴觉得还不错&#xff0c;有些则对LSI2308这块阵列卡性能表示不甚满意。 于是乎&#xff0c;就有了后续折腾的理由。 前一段时间&#xff0c;我还不了解阵列卡有啥区别&…

PostgreSQL10 物理流复制实战:构建高可用数据库架构!

背景 PostgreSQL 10 在高可用架构中提供了物理复制&#xff0c;也称为流复制&#xff08;Streaming Replication&#xff09;&#xff0c;用于实现实例级别的数据同步。PostgreSQL 复制机制主要包括物理复制和逻辑复制&#xff1a;物理复制依赖 WAL 日志进行物理块级别的同步&…

Linux网络安全技术与实现

&#x1f345; 点击文末小卡片 &#xff0c;免费获取网络安全全套资料&#xff0c;资料在手&#xff0c;涨薪更快 Linux 网络安全和优化 Jephe Wu 翻译整理 简介 网络安全是一个非常重要的课题,基本上你运行的服务后台越多,你就可能打开更多的安全漏洞.如果配置的恰当的话,Li…

[黑马点评]关于原子性,锁的笔记

不得不说&#xff0c;黑马点评是一个非常不错的课程&#xff0c;对于线程安全方面的讲解十分详细且明朗&#xff0c;故写下这篇笔记方便复习及帮助后人&#xff08;&#xff09; 目标 我们的目标是对于大量对于优惠劵的访问时&#xff0c;要防止超卖问题以及一人多单问题。 单J…