当前位置: 首页 > news >正文

C语言【数据结构】:理解什么是数据结构和算法(启航)

引言

        启航篇,理解什么是数据结构和算法

在 C 语言编程领域,数据结构算法是两个核心且紧密相关的概念

一、数据结构

定义

        数据结构是指相互之间存在一种或多种特定关系的数据元素的集合(比如数组),它是组织和存储数据的方式,目的是为了更高效地对数据进行访问、插入、删除、修改等操作。

        不同的数据结构适用于不同的应用场景,合理选择数据结构可以显著提高程序的性能。

下面以数组来理解一下 

例子:数组(Array)

        数组就是一种很简单的数据结构

        数组是一种线性数据结构,它由相同类型的元素组成,这些元素在内存中连续存储。可以通过下标快速访问数组中的任意元素。

#include <stdio.h>int main() {// 定义一个包含5个整数的数组int arr[5] = {1, 2, 3, 4, 5};// 访问数组元素for (int i = 0; i < 5; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}
        当然数据结构还有很多很多,这里是以数组作为一个例子,带你理解数据结构这个定义,如果还是不理解数据结构的话,没关系,当你学了许多数据结构后,你肯定会有理解,这时再看这个定义,就可以联想到那些数据结构,肯定是可以理解的

         数据结合和算法是相互配合使用的,下面来看什么是算法

二、算法

定义

        算法是指解决特定问题的一系列明确的、有限的操作步骤。它是对特定问题求解步骤的一种描述,是指令的有限序列,其中每一条指令表示一个或多个操作。算法具有有穷性、确定性、可行性、输入和输出等特性。

例子1. 排序算法 - 冒泡排序(Bubble Sort)

        冒泡排序是一种简单的排序算法,它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。

#include <stdio.h>// 冒泡排序
void bubbleSort(int arr[], int n) {for (int i = 0; i < n - 1; i++) {for (int j = 0; j < n - i - 1; j++) {if (arr[j] > arr[j + 1]) {int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}
}int main() {int arr[] = {64, 34, 25, 12, 22, 11, 90};int n = sizeof(arr) / sizeof(arr[0]);// 调用冒泡排序函数bubbleSort(arr, n);// 输出排序后的数组for (int i = 0; i < n; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

        这里的冒泡排序,就是一种算法,说白了,算法就是解决某个特定类型的问题而写的代码程序

例子2. 搜索算法 - 线性搜索(Linear Search)

        线性搜索是一种简单的搜索算法,它从数组的第一个元素开始,逐个比较元素,直到找到目标元素或遍历完整个数组。

#include <stdio.h>// 线性搜索
int linearSearch(int arr[], int n, int target) {for (int i = 0; i < n; i++) {if (arr[i] == target) {return i; // 找到目标元素,返回其下标}}return -1; // 未找到目标元素,返回 -1
}int main() {int arr[] = {10, 20, 30, 40, 50};int n = sizeof(arr) / sizeof(arr[0]);int target = 30;// 调用线性搜索函数int result = linearSearch(arr, n, target);if (result != -1) {printf("目标元素 %d 的下标是 %d\n", target, result);} else {printf("未找到目标元素 %d\n", target);}return 0;
}

         这里的搜索算法,就是一种算法,是为了解决搜索问题而有的代码

三、数据结构与算法的关系

        数据结构和算法是相辅相成的。

        数据结构是算法实现的基础,不同的数据结构会影响算法的实现方式和效率;

        算法则是对数据结构进行操作的具体步骤,合理的算法可以充分发挥数据结构的优势,提高程序的性能。

        例如,在一个大规模的数据集合中进行查找操作,如果使用数组存储数据,可能使用线性搜索算法,时间复杂度为 O(n);如果使用哈希表这种数据结构,结合哈希查找算法,平均时间复杂度可以达到 O(1)。(看不懂没关系,以后学到了肯定就明白了)。


http://www.mrgr.cn/news/94399.html

相关文章:

  • 【愚公系列】《高效使用DeepSeek》001-什么是DeepSeek
  • 蓝桥杯 之 回溯之充分剪枝
  • Docker基础命令说明
  • 【技术白皮书】内功心法 | 第二部分 | Telnet远程登录的工作原理
  • 芯片研发不需要PPT
  • 计算机视觉|首次写入政府工作报告!这个科技新词“具身智能”到底是什么?
  • 【NLP 33、实践 ⑦ 基于Triple Loss作表示型文本匹配】
  • Linux---VI/VIM编辑器
  • 【算法】数组、链表、栈、队列、树
  • LeetCode 第8题:字符串转换整数 (atoi)
  • 个性化音乐推荐系统
  • 【菜鸟飞】通过vsCode用python访问公网deepseek-r1等模型(Tocken模式)
  • onnxruntime-gpu与cuda版本对应及是否能调用cuda测试
  • C盘清理技巧分享:释放空间,提升电脑性能
  • 色板在数据可视化中的创新应用
  • vue3 中使用 Recorder 实现录音并上传,并用Go语言调取讯飞识别录音(Go语言)
  • Xxl-Job学习笔记
  • python学习笔记-mysql数据库操作
  • excel中两个表格的合并
  • 网络通信(传输层协议:TCP/IP ,UDP):