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

C语言-02 算法-程序的灵魂

算法-程序的灵魂

  • 1、程序=算法+数据结构
  • 2、什么是算法
  • 3、简单的算法举例
  • 4、算法的特性
  • 5、怎样表示一个算法
    • 5.1 用自然语言表示算法
    • 5.2 用流程图表示算法
    • 5.3 三种基本结构和改进的流程图
    • 5.4 用N-S流程图表示算法
    • 5.5 用伪代码表示算法
    • 5.6 用计算机语言表示算法
  • 6、结构化程序设计方法

1、程序=算法+数据结构

 
  在计算机科学中,程序是由算法和数据结构组成的。算法是解决问题的步骤,而数据结构则是存储和组织数据的方式。两者紧密结合,共同决定了程序的效率和功能。

2、什么是算法

 
  算法是指解决特定问题的一系列步骤或规则。它描述了如何从输入得到输出,并且必须在有限的步骤内完成。算法的关键在于正确性、效率和可维护性。

3、简单的算法举例

 
以计算两个数的最大公约数为例,经典的欧几里得算法步骤如下:

  • 1:给定两个正整数 ab
  • 2:如果 b 为 0,则 a 即为最大公约数。
  • 3:否则,计算 a % b 并将结果赋值给 b
  • 4:交换 ab 的值,重复步骤 2 和 3,直到 b 为 0。

4、算法的特性

 
一个好的算法应具有以下特性:

  • 有穷性:算法必须在有限的步骤内结束。
  • 确定性:算法的每一步骤必须明确、无歧义。
  • 输入:算法应有0个或多个输入。
  • 输出:算法应有一个或多个输出。
  • 可行性:算法的每一步骤都应是可行的,能够通过有限的操作实现。

5、怎样表示一个算法

5.1 用自然语言表示算法

 
  自然语言描述算法直观易懂,但容易产生歧义。适用于简单的算法描述,例如前述的欧几里得算法。

5.2 用流程图表示算法

 
  流程图通过图形表示算法的执行流程,每个步骤用方框或其他形状表示,流程用箭头连接。流程图清晰直观,适合表达算法的整体结构。
        在这里插入图片描述

5.3 三种基本结构和改进的流程图

 
流程图通常由三种基本结构构成:

  • 顺序结构:按步骤顺序执行。
  • 选择结构:根据条件执行不同分支。
  • 循环结构:重复执行某些步骤。

通过这些基本结构,可以绘制出更加复杂的流程图来表示复杂算法。

5.4 用N-S流程图表示算法

 
  Nassi-Shneiderman(N-S)流程图是另一种表示算法的方法。它使用嵌套矩形来表示算法的控制结构。N-S流程图比传统流程图更加结构化,更能体现程序设计的层次。
  示例:
 
在这里插入图片描述

5.5 用伪代码表示算法

 
  伪代码是一种介于自然语言和编程语言之间的表示方法。它没有固定的语法规则,更注重描述算法的逻辑步骤。伪代码简洁明了,便于转换成实际代码。例如,用于计算一个整数数组的最大值的伪代码:

Function FindMax(Array, n)max = Array[0]For i = 1 to n-1 DoIf Array[i] > max Thenmax = Array[i]End IfEnd ForReturn max
End Function

这个伪代码的功能是遍历一个数组 Array,并找到其中的最大值。n表示数组的元素数量,max用于存储当前找到的最大值。

5.6 用计算机语言表示算法

 
  算法可以用计算机语言来表示。这是最直接的表示方式,也就是将算法转换成可执行的程序代码。以C语言为例,实现上面的阶乘算法:

#include <stdio.h>int FindMax(int array[], int n) {int max = array[0]; // 初始化最大值为数组的第一个元素for (int i = 1; i < n; i++) { // 从第二个元素开始遍历数组if (array[i] > max) { // 如果当前元素大于当前最大值max = array[i];   // 更新最大值}}return max; // 返回找到的最大值
}int main() {int n;printf("Enter the number of elements: "); // 提示用户输入数组元素的数量scanf("%d", &n); // 获取用户输入的数组元素数量int array[n];printf("Enter the elements:\n"); // 提示用户输入数组元素for (int i = 0; i < n; i++) {scanf("%d", &array[i]); // 获取用户输入的数组元素}int max = FindMax(array, n); // 调用函数计算数组中的最大值printf("The maximum value is: %d\n", max); // 输出最大值return 0; // 程序结束
}

6、结构化程序设计方法

 
  结构化程序设计方法是指通过使用顺序、选择和循环三种基本结构,设计出清晰、易理解和维护的程序。C语言本身非常适合结构化程序设计,通过合理使用函数、循环和条件语句,可以编写出结构良好的代码。
 
举例:计算数组元素的平均值
 
  结构化程序设计的一个简单例子是计算数组中元素的平均值。该程序将输入一个整数数组,然后输出其平均值。

#include <stdio.h>int main() {int n, i; // 声明整型变量 n 和 idouble sum = 0.0, average; // 声明并初始化 sum 为 0.0,声明 average 变量printf("Enter the number of elements: "); // 提示用户输入元素数量scanf("%d", &n); // 获取用户输入的元素数量并存储在 n 中double array[n]; // 声明一个大小为 n 的 double 类型数组for (i = 0; i < n; i++) { // 循环遍历数组printf("Enter element %d: ", i + 1); // 提示用户输入第 i+1 个元素scanf("%lf", &array[i]); // 获取用户输入的元素并存储在数组中sum += array[i]; // 将输入的元素值累加到 sum}average = sum / n; // 计算平均值printf("Average = %.2lf\n", average); // 输出平均值,保留两位小数return 0; // 程序结束,返回 0 表示成功执行
}

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

相关文章:

  • [随便学学]在doker服务器中实现ssh免密登陆
  • 第二代骁龙8平台手机nubia Z5拆解
  • C语言进阶(三)自定义类型:联合和枚举
  • 【STM32】定时器
  • 无线通信频率分配
  • [vue] 按钮限制连点
  • 零差云控电机ubuntu+IGH调试记录
  • 不改一行代码轻松玩转 Go 应用微服务治理
  • Shell 脚本入门指南
  • ubuntu20 安装ros noetic版本
  • ONNX加载和保存模型
  • 【零知识证明】MiMC哈希函数电路
  • [米联客-XILINX-H3_CZ08_7100] FPGA程序设计基础实验连载-11 UART串口接收驱动设计
  • 【FPGA】HDMI参数信息汇总
  • 宠物空气净化器哪款更值得推荐?希喂和352哪款更好?
  • 35岁零基础能转型AI大模型吗?
  • CSS 终于在 2024 年增加了垂直居中功能
  • Qt调用外部exe并嵌入到Qt界面中(验证成功的成功)
  • 如何解决:Failed to start jenkins.service: Unit not found.
  • P1009 【深基4,例7】阶乘之和