求一个一维数组的最大值,最小值和平均值〔主函数调用并输出〕。用c语言,不要用指针
时间: 2024-03-05 11:55:12 浏览: 42
好的,下面是代码:
```c
#include <stdio.h>
#define SIZE 10
int main()
{
int arr[SIZE] = {5, 3, 8, 9, 1, 2, 7, 4, 6, 0}; // 定义一个一维数组
int max = arr[0], min = arr[0], sum = 0; // 初始化最大值、最小值和总和
// 循环遍历数组,找出最大值、最小值和总和
for (int i = 0; i < SIZE; i++) {
if (arr[i] > max) {
max = arr[i];
}
if (arr[i] < min) {
min = arr[i];
}
sum += arr[i];
}
// 计算平均值
float avg = sum * 1.0 / SIZE;
// 输出结果
printf("最大值:%d\n", max);
printf("最小值:%d\n", min);
printf("平均值:%.2f\n", avg);
return 0;
}
```
这个程序定义了一个大小为10的一维数组,并且找出了数组中的最大值、最小值和总和,然后计算出平均值并输出。请注意,这个程序没有使用指针。
相关问题
求一个一维数组的最大值,最小值和平均值〔主函数调用并输出〕。用c语言
好的,下面是一段实现你需要的功能的 C 代码:
```c
#include <stdio.h>
#define SIZE 5
void calc(int arr[], int size, int* max, int* min, double* avg) {
int sum = 0;
*max = arr[0];
*min = arr[0];
for (int i = 0; i < size; i++) {
if (arr[i] > *max) {
*max = arr[i];
}
if (arr[i] < *min) {
*min = arr[i];
}
sum += arr[i];
}
*avg = (double) sum / size;
}
int main() {
int arr[SIZE] = {2, 5, 1, 8, 3};
int max, min;
double avg;
calc(arr, SIZE, &max, &min, &avg);
printf("最大值: %d\n", max);
printf("最小值: %d\n", min);
printf("平均值: %.2f\n", avg);
return 0;
}
```
这段代码中,`calc` 函数用于计算最大值、最小值和平均值,其中 `arr` 是输入的数组,`size` 是数组的大小,`max`、`min` 和 `avg` 是输出参数,分别用于存储最大值、最小值和平均值。在主函数中,我们定义了一个大小为 `SIZE` 的数组,调用 `calc` 函数计算最大值、最小值和平均值,并输出到控制台。
注意,我们用指针作为输出参数,可以在函数内部修改这些参数的值,从而实现返回多个值的效果。同时,我们使用了 `double` 类型来存储平均值,避免了整型除法带来的精度问题。
利用C语言编写程序,用指针计算二维数组,a[3][4]每一行中的最大值最小值以及平均值
### 回答1:
#include <stdio.h>
int main() {
int a[3][4] = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}};
int i, j;
int max, min, sum;
float avg;
max = a[0][0];
min = a[0][0];
sum = 0;
for (i = 0; i < 3; i++) {
for (j = 0; j < 4; j++) {
if (a[i][j] > max) {
max = a[i][j];
}
if (a[i][j] < min) {
min = a[i][j];
}
sum += a[i][j];
}
}
avg = (float) sum / 12;
printf("最大值:%d\n", max);
printf("最小值:%d\n", min);
printf("平均值:%f\n", avg);
return 0;
}
这是一个用C语言编写的程序,计算二维数组a[3][4]中每行的最大值、最小值和平均值。程序首先定义一个3行4列的二维数组a,并初始化各元素的值。然后,程序使用两个for循环遍历数组a的所有元素,计算每行的最大值、最小值和总和。最后,程序计算平均值并输出结果。
请注意,本程序假设数组中的值都是整数,因此在计算平均值时需要进行类型转换。如果您使用的是其他类型的数组元素,请相应地修改类型转换操作。
### 回答2:
要使用C语言编写程序来计算二维数组a[3][4]每一行中的最大值、最小值和平均值,可以通过指针来实现。下面是一个示例程序:
#include <stdio.h>
void calculateRowValues(int *ptr, int rowSize, int colSize) {
int row, col;
int max, min;
double sum, average;
for (row = 0; row < rowSize; row++) {
max = *(ptr + row * colSize); // 以首元素作为初始最大值
min = *(ptr + row * colSize); // 以首元素作为初始最小值
sum = 0;
for (col = 0; col < colSize; col++) {
int value = *(ptr + row * colSize + col);
if (value > max) {
max = value;
}
if (value < min) {
min = value;
}
sum += value;
}
average = sum / colSize;
printf("第%d行的最大值:%d\n", row + 1, max);
printf("第%d行的最小值:%d\n", row + 1, min);
printf("第%d行的平均值:%f\n", row + 1, average);
}
}
int main() {
int a[3][4] = {
{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12}
};
calculateRowValues(&a[0][0], 3, 4);
return 0;
}
在该示例程序中,calculateRowValues()函数用于计算每一行的最大值、最小值和平均值。首先,该函数接收指向二维数组首元素的指针,以及行数和列数作为参数。然后,使用嵌套的for循环遍历每一行和每一列,从而计算出最大值、最小值和总和。最后,通过除以列数来计算平均值。在主函数main()中,创建了一个3行4列的二维数组a,并将其地址传递给calculateRowValues()函数进行计算。运行程序后,会依次输出每一行的最大值、最小值和平均值。
### 回答3:
使用C语言编写程序来计算二维数组a[3][4]每一行的最大值、最小值和平均值可以通过以下代码实现:
```c
#include <stdio.h>
void calculate(int a[3][4], int rows, int cols) {
int row, col;
int *ptr;
int max, min;
float sum, avg;
for (row = 0; row < rows; row++) {
ptr = a[row];
max = *ptr;
min = *ptr;
sum = 0;
for (col = 0; col < cols; col++) {
if (*ptr > max) {
max = *ptr;
}
if (*ptr < min) {
min = *ptr;
}
sum += *ptr;
ptr++;
}
avg = sum / cols;
printf("第%d行:最大值:%d,最小值:%d,平均值:%.2f\n", row + 1, max, min, avg);
}
}
int main() {
int a[3][4] = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}};
calculate(a, 3, 4);
return 0;
}
```
在这个程序中,我们定义了一个`calculate`函数,该函数接受一个二维数组`a`、行数`rows`和列数`cols`作为参数。首先,我们通过循环遍历每行,然后通过一个内部循环遍历每一行中的元素。
我们使用一个指针`ptr`来依次指向每个元素。在内部循环中,我们使用`ptr`来比较元素,并找到该行的最大值和最小值。同时,我们将每个元素的值累加到`sum`中,以便计算平均值。
最后,我们打印出每行的最大值、最小值和平均值。
在`main`函数中,我们定义了一个`3 x 4`的二维数组`a`,并调用`calculate`函数来计算每行的最大值、最小值和平均值。
注意:这里默认二维数组的行数为3,列数为4,如果想要计算其他大小的二维数组,只需在main函数中更改数组的大小和元素的值即可。