本文主要是介绍C语言题目:数组寻找最小绝对值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题目描述
输入10个数,找出其中绝对值最小的数,将它和最后一个数交换,然后输出这10个数。
输入格式
十个数
输出格式
交换后的十个数
样例输入
10 2 30 40 50 60 70 80 90 100
样例输出
10 100 30 40 50 60 70 80 90 2
代码解析
-
包含标准输入输出库和数学库:
#include <stdio.h>
和#include <math.h>
这两行代码是预处理指令,它们告诉编译器在实际编译之前包含标准输入输出库和数学库。标准输入输出库提供了进行输入输出操作的功能,如printf
和scanf
函数。数学库提供了数学函数的支持,如fabs
函数。 -
定义主函数:
int main(void)
是C程序的入口点,void
表示这个函数不接受任何参数。 -
定义变量:
int arr[10]
:定义了一个整型数组,用于存储用户输入的10个整数。int min
:用于记录最小值的索引。int minnum
:用于记录当前找到的最小值。int t
:用于交换数值的临时变量。
-
输入第一个数并初始化最小值:
scanf("%d", &arr[0]);
这个函数调用用于从标准输入读取第一个整数,并存储在数组的第一个位置。minnum = arr[0];
将数组的第一个元素赋值给minnum
,作为当前的最小值。 -
找出最小值:
- 进入一个
for
循环,循环变量i
从1开始,直到9,因为数组的前10个位置中的前一个已经输入并存储。 - 在每次循环中,使用
scanf
函数读取下一个整数,并存储在数组的相应位置。 - 使用
fabs
函数计算当前最小值minnum
和当前读取的数arr[i]
的绝对值,然后比较它们的大小。 - 如果
arr[i]
的绝对值小于minnum
的绝对值,更新min
为当前的索引i
,并将arr[i]
的值赋给minnum
,作为新的最小值。
- 进入一个
-
交换最小值到数组末尾:
- 使用变量
t
作为临时存储,将数组的最后一个元素arr[9]
保存到t
中。 - 将找到的最小值
arr[min]
赋值给数组的最后一个位置arr[9]
。 - 最后,将
t
中的值赋值给数组的min
索引位置。
- 使用变量
-
输出调整后的数组:
- 进入一个
for
循环,循环变量i
从0开始,直到9,遍历数组的每个元素。 - 使用
printf
函数输出数组的每个元素,后面跟着一个空格。
- 进入一个
-
输出换行符:
printf("\n");
输出一个换行符,表示输出结束。 -
函数返回:
return 0;
表示main
函数执行成功并返回0。在C语言中,main
函数的返回值通常用于表示程序的退出状态,其中0表示成功。
源代码
#include <stdio.h>
#include <math.h>
int main(void)
{int arr[10];int min = 0;int minnum;int t;scanf("%d", &arr[0]);minnum = arr[0];for (int i = 1; i < 10; i++){scanf("%d", &arr[i]);if (fabs(minnum) > fabs(arr[i])){min = i;minnum = arr[i];}}t = arr[9];arr[9] = arr[min];arr[min] = t;for (int i = 0; i < 10; i++){printf("%d ", arr[i]);}printf("\n");return 0;
}
这篇关于C语言题目:数组寻找最小绝对值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!