/*
递归master公式
T(N)的公式从大规模来看,不细分。
T(N) = a * T(N/b)+O(n^d)
N/b 是子过程数据量 ;a是子过程调用多少次;O(n^d)是出去
过程之外剩下的数据量的多少
if log(b)a > d => O(N^log(b)a)
if log(b)a = d => O(N^d *logN)
if log(b)a < d => O(N^d)
注意 多个递归的规模必须一样,否则master公式失效。
例如一个规模是1/3;一个是2/3;
以下算法的时间复杂度:a = 2;b = 2;d = 0;所以时间复杂度为O(N)
*/
int process(int arr[] ,int L,int R){
if (L == R) {//base case;
return arr[L];
}
int mid = (L+R)/2;
int LeftMax = process(arr, L, mid);
int RightMax = process(arr, mid+1 , R);
return (LeftMax /RightMax)?LeftMax : RightMax;
}
int getMaxInArray(int arr[],int length){
return process(arr , 0 , length-1);
}