c语言数组最大可定义多少位_C语言求数组的最大值三种方法
生活随笔
收集整理的這篇文章主要介紹了
c语言数组最大可定义多少位_C语言求数组的最大值三种方法
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
/* 黃哥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("數(shù)組中的元素最大值 = %d", maxValue(arr, sizeof(arr)/sizeof(arr[0]))); printf("數(shù)組中的元素最大值 = %d", maxRecursionValue(arr, sizeof(arr)/sizeof(arr[0]))); printf("數(shù)組中的元素最大值 = %d", maxDividAndConquerValue(arr, 0, sizeof(arr)/sizeof(arr[0]) - 1)); return 0;}int maxValue(int* arr, int n) { // 假定數(shù)組最少有一個元素 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 都很大的情況下,可能會導(dǎo)致溢出問題,所以一般寫成 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語言求數(shù)組的最大值三種方法視頻播放地址
總結(jié)
以上是生活随笔為你收集整理的c语言数组最大可定义多少位_C语言求数组的最大值三种方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Kotlin静态方法定义和调用
- 下一篇: Android日志[基础篇]Androi