/* 黄哥Python培训 黄哥所写*/#include int maxValue(int* arr, int n);int maxRecursionValue(int* arr, int n);int maxDividAndConquerValue(int* arr, int left, int right);int main(void) { int arr[] = {500, -1, 30, 7, 99, 12}; printf("数组中的元素最大值 = %d", maxValue(arr, sizeof(arr)/sizeof(arr[0]))); printf("数组中的元素最大值 = %d", maxRecursionValue(arr, sizeof(arr)/sizeof(arr[0]))); printf("数组中的元素最大值 = %d", maxDividAndConquerValue(arr, 0, sizeof(arr)/sizeof(arr[0]) - 1)); return 0;}int maxValue(int* arr, int n) { // 假定数组最少有一个元素 int max = arr[0]; for (int i = 1; i < n; i++) { if (arr[i] > max) { max = arr[i]; } } return max;}int maxRecursionValue(int* arr, int n) { if (n == 0) { return 0; } int max1 = arr[n- 1]; int max2 = maxRecursionValue(arr, n - 1); return max1 > max2? max1:max2;}int maxDividAndConquerValue(int* arr, int left, int right){ if (left == right) { return arr[left]; } // int mid = (left + right) / 2; // 可能有bug mid = (left + right)/2,如果 left 和 right 都很大的情况下,可能会导致溢出问题,所以一般写成 mid = left + (right-left)/2。 int mid = left + (right- left) / 2; int max1 = maxDividAndConquerValue(arr, left, mid); int max2 = maxDividAndConquerValue(arr, mid + 1, right); return max1 > max2? max1:max2;}
C语言求数组的最大值三种方法视频播放地址