通过指针遍历数组查找最大值,先定义指向首元素的指针ptr和记录最大值地址的maxPtr,从第二个元素开始比较并更新maxPtr,最终输出最大值及其内存地址。

在C++中,可以使用指针来遍历数组并查找最大值。这种方法不使用数组下标,而是通过移动指针访问每个元素,适合理解指针和内存操作的基本原理。
定义指针并初始化
声明一个指向数组首元素的指针,并用另一个指针记录最大值的位置。
- 让指针 ptr 指向数组第一个元素
- 用 maxPtr 跟踪当前最大值所在的地址
- 从第二个元素开始比较,逐步更新 maxPtr
通过指针遍历查找最大值
使用指针递增的方式遍历整个数组,比较每个元素与当前最大值。
#includeusing namespace std; int main() { int arr[] = {10, 45, 23, 67, 12, 89}; int n = sizeof(arr) / sizeof(arr[0]);
int* ptr = arr; // 指向数组首元素 int* maxPtr = ptr; // 假设第一个元素最大 for (int i = 1; i < n; ++i) { ++ptr; if (*ptr > *maxPtr) { maxPtr = ptr; } } cout << "最大值是: " << *maxPtr << endl; cout << "位于地址: " << maxPtr << endl; return 0;}
直接用指针控制循环条件
更“纯粹”的指针写法:用指针加偏移和地址比较来控制循环。
立即学习“C++免费学习笔记(深入)”;
int* start = arr; int* end = arr + n; int* maxPtr = start;for (int p = start + 1; p < end; ++p) { if (p > maxPtr) { maxPtr = p; } } cout << "最大值: " << maxPtr << endl;
基本上就这些。用指针查找最大值关键是理解 *ptr 获取值,++ptr 移动到下一个元素,以及用地址比较控制循环范围。这种方式效率高,也利于深入掌握指针操作。










