面試題11. 旋轉(zhuǎn)數(shù)組的最小數(shù)字 C實現(xiàn)

//二分法  
int minArray(int* numbers, int numbersSize){
  int left = 0;
  int right = numbersSize - 1;
  while (left < right) {
    int mid = (left + right) / 2;
    if (numbers[mid] > numbers[right]) {
      left = mid + 1;
    }
    else if (numbers[mid] == numbers[right] && numbers[mid] == numbers[left]) {
        left += 1;
        right -= 1;
    }
    else {
      right = mid;
    }
  }
  return numbers[left];
 
}
//前后齊頭并進
int minArray1(int* numbers, int numbersSize){
    int ans = numbers[0];
    int left = 0;
    int right = numbersSize - 1;
    int mid = (numbersSize + 1) / 2;
    while (left != mid) {
        if (ans > numbers[left]) {
            ans = numbers[left];
        }
        if (ans > numbers[right]) {
            ans = numbers[right];
        }
        left++;
        right--;
    }
    return ans;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容