三、基础实验 1. 编程实现:定义一个int类型的一维数组,数组长度为10。 要求:(1)用scanf函数完成数组的初始化 (2) 输出最大值及最大值在数组中的下标,若不止一个输出第一个即可。 (3)用冒泡法或选择对数据进行升序排序。
时间: 2024-11-25 18:11:35 浏览: 63
首先,让我们一步步地创建这个程序并满足所有的要求。
**步骤1:定义数组**
```c
#include <stdio.h>
#define ARRAY_LENGTH 10
// 定义整型数组
int arr[ARRAY_LENGTH];
```
**步骤2:使用scanf函数初始化数组**
```c
int main() {
// 使用循环和 scanf 函数初始化数组
for (int i = 0; i < ARRAY_LENGTH; i++) {
printf("Enter element %d: ", i + 1);
scanf("%d", &arr[i]);
}
// 这里我们没有直接求最大值,因为要先保存数组元素
int max_value = arr[0], max_index = 0;
}
```
**步骤3:寻找并输出最大值和下标**
```c
// 找最大值和它的下标
for (int i = 0; i < ARRAY_LENGTH; i++) {
if (arr[i] > max_value) {
max_value = arr[i];
max_index = i;
}
}
printf("The maximum value is %d and its index is %d.\n", max_value, max_index);
```
**步骤4:使用冒泡排序算法进行升序排序**
```c
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;
}
}
}
}
// 在主函数结束后排序数组
bubbleSort(arr, ARRAY_LENGTH);
return 0;
}
```
现在你可以整合这些代码段到一起:
```c
#include <stdio.h>
#define ARRAY_LENGTH 10
// 定义整型数组
int arr[ARRAY_LENGTH];
int main() {
// 初始化数组
for (int i = 0; i < ARRAY_LENGTH; i++) {
printf("Enter element %d: ", i + 1);
scanf("%d", &arr[i]);
}
// 寻找最大值和下标
int max_value = arr[0], max_index = 0;
for (int i = 0; i < ARRAY_LENGTH; i++) {
if (arr[i] > max_value) {
max_value = arr[i];
max_index = i;
}
}
printf("The maximum value is %d and its index is %d.\n", max_value, max_index);
// 冒泡排序
bubbleSort(arr, ARRAY_LENGTH);
return 0;
}
void bubbleSort(int arr[], int n) {
// 冒泡排序代码...
}
```
阅读全文