#include <iostream> using namespace std; int* findmin(int *minIndex, int a[], int size=10); double* findmin(int *minIndex, double a[], int size=10); int main() { int arr1[] = {5, 3, 8, 1, 9, 2}; int n1 = sizeof(arr1) / sizeof(arr1[0]); int minIndex1; int* ptr1 = findmin(&minIndex1, arr1, n1); cout << "The minimum value in the integer array is: " << *ptr1 << ", and its index is: " << minIndex1 << endl; double arr2[] = {5.1, 3.2, 8.5, 1.2, 9.7, 2.4}; int n2 = sizeof(arr2) / sizeof(arr2[0]); int minIndex2; double* ptr2 = findmin(&minIndex2, arr2, n2); cout << "The minimum value in the double array is: " << *ptr2 << ", and its index is: " << minIndex2 << endl; return 0; } int* findmin(int *minIndex, int a[], int size) { int min_val = a[0]; *minIndex = 0; for (int i = 1; i < size; i++) { if (a[i] < min_val) { min_val = a[i]; *minIndex = i; } } return &a[*minIndex]; } double* findmin(int *minIndex, double a[], int size) { double min_val = a[0]; *minIndex = 0; for (int i = 1; i < size; i++) { if (a[i] < min_val) { min_val = a[i]; *minIndex = i; } } return &a[*minIndex]; }代码解释
时间: 2024-03-30 11:38:30 浏览: 60
这段代码定义了两个函数 `findmin`,一个是针对整型数组的,一个是针对双精度浮点型数组的。这两个函数都接受一个指向数组的指针、一个指向 `minIndex` 的指针和数组的大小作为参数。这两个函数的返回值都是指向最小值所在数组元素的指针。在 `main` 函数中,分别定义了一个整型数组和一个双精度浮点型数组,并调用了两次 `findmin` 函数分别计算出最小值和最小值所在的数组下标,并输出到屏幕上。
相关问题
#include <iostream> using namespace std; int* findmin(int* minIndex, int a[], int size=10) { if (size <= 0) return NULL; int minVal = a[0]; *minIndex = 0; for (int i = 1; i < size; i++) { if (a[i] < minVal) { minVal = a[i]; *minIndex = i; } } return &a[*minIndex]; } double* findmin(int* minIndex, double a[], int size = 10) { if (size <= 0) return NULL; double minVal = a[0]; *minIndex = 0; for (int i = 1; i < size; i++) { if (a[i] < minVal) { minVal = a[i]; *minIndex = i; } } return &a[*minIndex]; } int main() { int a[10]; double b[10]; cout << "Please input 10 integers: " << endl; for (int i = 0; i < 10; i++) { cin >> a[i]; } int minIndex; int* p = findmin(&minIndex, a); cout << "The minimum value is: "<< *p << endl; cout << "It's minIndex is: "<< minIndex << endl; cout << "Please input 10 decimals: " << endl; for (int i = 0; i < 10; i++) { cin >> b[i]; } minIndex = 0; double* q = findmin(&minIndex, b); cout << "The minimum value is: "<< *q << endl; cout << "It's minIndex is: "<< minIndex << endl; return 0; }
这段代码实现了两个重载函数 `findmin`,分别用于在整型数组和双精度浮点型数组中查找最小值,并返回其指针。函数中采用了指针方式获取最小值的下标,同时也提供了一个默认参数 `size=10`,表示数组的大小默认为10。在主函数中,通过输入10个整型数和10个双精度浮点型数,分别调用了两个函数,并输出了最小值和其下标。
#include <iostream> using namespace std; template<typename T> T* findmin(int *minIndex, T a[], int size=10){ T *minValue = &a[0]; *minIndex = 0; for(int i=1;i<size;i++){ if(a[i] < *minValue){ minValue = &a[i]; *minIndex = i; } } return minValue; } int main(){ int minIndex; int a[10]; double b[10]; cout << "Please input ten integers:" << endl; for(int i=0;i<10;i++) cin >> a[i]; int *minIntPtr = findmin(&minIndex, a); cout << "The minimum value is:" << *minIntPtr << endl; cout << "It's minIndex is: " << minIndex << endl; cout << "Please input ten decimals: " << endl; for(int i=0;i<10;i++) cin >> b[i]; double *minDoublePtr = findmin(&minIndex, b); cout << "The minimum value is:" << *minDoublePtr << endl; cout << "It's minIndex is: " << minIndex << endl; return 0; }
这段代码是一个查找数组中最小值的函数模板,并在主函数中分别调用了两次,分别传入了一个整型数组和一个双精度浮点型数组。函数模板的具体实现如下:
```c++
template<typename T>
T* findmin(int *minIndex, T a[], int size=10){
T *minValue = &a[0]; // 定义指向最小值的指针,初始化为数组的第一个元素
*minIndex = 0; // 记录最小值的下标,初始化为0
for(int i=1;i<size;i++){
if(a[i] < *minValue){ // 如果找到了比当前最小值更小的元素
minValue = &a[i]; // 更新最小值指针
*minIndex = i; // 更新最小值下标
}
}
return minValue; // 返回最小值指针
}
```
在主函数中,先使用 `cin` 输入了一个长度为 10 的整型数组 `a`,然后调用函数模板 `findmin`,将数组名 `a` 作为参数传入,并传入一个指向 `minIndex` 的指针,用于记录最小值的下标。函数模板返回一个指向最小值的指针,可以通过解引用操作符 `*` 获取最小值本身。最后输出最小值和其下标。
接下来再使用 `cin` 输入了一个长度为 10 的双精度浮点型数组 `b`,并重复调用了一次 `findmin` 函数模板,输出了该数组中的最小值和其下标。
需要注意的是,函数模板的第三个参数 `size` 默认值为 10,表示如果在调用函数模板时没有传入该参数,将自动使用默认值 10。
阅读全文