演算法小記

來源:互聯網
上載者:User

標籤:source   演算法   pre   nlog   最大子序列和   length   +=   arch   常數時間   

只要在常數時間內可以將問題的大小削減為其一部分($ \frac{1}{2} $), 那麼該演算法就是($O(logN)$)

  1. 最大子序列和問題($O(NlogN)$)

    public static int maxSubSum(int[] arr) {int maxSum = 0, thisSum = 0;for (int i = 0; i < arr.length; i++) {    thisSum += arr[i];    if (thisSum > maxSum) {        maxSum = thisSum;    } else if (thisSum < 0) {        thisSum = 0;    }}return maxSum;}
  2. 折半尋找binary search($O(logN)$)

    public static int binarySearch(int[] arr, int x) {    int low = 0, high = arr.length - 1;    while (low <= high) {        int mid = (low + high)/2;        if (arr[mid] < x) {            low = ++mid;        } else if (arr[mid] > x) {            high = --mid;        } else {            return mid;        }    }    return -1;}

演算法小記

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.