当前位置: 首页 > 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)。(看不懂没关系,以后学到了肯定就明白了)。

 

相关文章:

  • c++类和对象(下篇)上
  • 项目组织管理类型-矩阵式组织和组合式组织的区别
  • 数据结构——顺序表seqlist
  • 学习率调整策略
  • QT系列教程(19) Qt MVC结构之QItemDelegate介绍
  • FSC森林认证:推动全球森林的可持续管理
  • 记录一个SQL自动执行的html页面
  • 最短路算法
  • 【微知】tmux中如何让某个窗口或者子窗口显示时间(ctrl + b t)
  • 【Linux学习笔记】Linux用户和文件权限的深度剖析
  • [HUBUCTF 2022 新生赛]messy_traffic
  • JAVA中的多线程安全问题及解决方案
  • kafka连问
  • 掌握xtquant:高效获取市场基础信息的实战指南
  • js数组常用方法与技巧
  • 累计完工数量达到了xxxx超过了最大可完工数量xxxx
  • C++ 邻接矩阵(代码)
  • 【微知】plantuml在泳道图中如何将几个步骤放入一个框中?(group “sub框1“; end !! “sub框1“)
  • 5-24 色彩与风格——T2IA自适应
  • 【医院绩效管理专题】8.医院绩效数据的收集与整理方法:洞察现状,引领未来
  • 七牛直播网站怎么做/苏州疫情最新通知
  • 个人网站备案类型/网络营销策划论文
  • 查看别人网站的访问量/宁波seo整体优化
  • 公司注册核名在哪个网站/小程序开发哪家好
  • 网站建设的辅助软件/网络seo优化公司
  • 网站要怎么做才能让360收录/北京口碑最好的教育机构