日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

求最大子段和的一些算法

發布時間:2023/12/31 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 求最大子段和的一些算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
public class MaxSubSeqSum {/*** 算法1,窮舉搜索*/public static final int maxSubSeqSum1(int seq[]) {int length = seq.length;int sum = 0;for (int i = 0; i < length; i++) {for (int j = i; j < length; j++) {int theSum = 0;for (int k = i; k <= j; k++) {theSum += seq[k];}if (sum < theSum) sum = theSum;}}return sum;}/*** 算法2。改進算法1*/public static final int maxSubSeqSum2(int seq[]) {int length = seq.length;int sum = 0;for (int i = 0; i < length; i++) {int theSum = 0;for (int j = i; j < length; j++) {theSum += seq[j];if (theSum > sum) {sum = theSum;}}}return sum;}/*** 算法3:分治法*/public static final int maxSubSeqSum3(int seq[]) {return maxSubSeqSum31(seq, 0, seq.length - 1);}private static int max(int... args) {int max = Integer.MIN_VALUE;for (int i : args) {if (i > max) max = i;}return max;}private static final int maxSubSeqSum31(int[] seq, int left, int right) {if (right - left == 1) { // 僅僅剩下兩個了:return max(seq[left], seq[right], seq[left] + seq[right], 0);} else if (left == right) {return max(seq[left], 0);} else {int middle = (left + right) / 2;int maxLeft = maxSubSeqSum31(seq, left, middle);int maxRight = maxSubSeqSum31(seq, middle + 1, right);int maxMiddle = maxSubSeqMiddle(seq, left, right, middle);return max(maxLeft, maxRight, maxMiddle);}}private static final int maxSubSeqMiddle(int[] seq, int left, int right, int middle) {int maxLeft = 0, maxRight = 0;int temp = 0;for (int i = middle; i >= left; i--) {temp += seq[i];if (maxLeft < temp) {maxLeft = temp;}}temp = 0;for (int i = middle + 1; i <= right; i++) {temp += seq[i];if (maxRight < temp) {maxRight = temp;}}return max(maxLeft, maxRight, maxLeft + maxRight);}/*** 最快的計算方式* @param seq* @return*/public static final int maxSubSeqSum4(int seq[]) {int sum = 0, theSum = 0;int length = seq.length;for (int i = 0; i < length; i++) {theSum = max(theSum + seq[i], 0);if (sum < theSum) {sum = theSum;}}return sum;}public static void main(String[] args) throws Exception {int length = 100000;int[] arr = new int[length];Random rand = new Random(10);for (int i = 0; i < length; i++) {arr[i] = rand.nextInt(11) - 5;}long t = System.currentTimeMillis(); // int ret1 = maxSubSeqSum1(arr); // System.out.println("算法1耗時:" + (System.currentTimeMillis() - t)); // System.out.println("結果1:" + ret1); // t = System.currentTimeMillis();int ret2 = maxSubSeqSum2(arr);System.out.println("算法2耗時:" + (System.currentTimeMillis() - t));System.out.println("結果2:" + ret2);t = System.currentTimeMillis();int ret3 = maxSubSeqSum3(arr);System.out.println("算法3耗時:" + (System.currentTimeMillis() - t));System.out.println("結果3:" + ret3);t = System.currentTimeMillis();int ret4 = maxSubSeqSum4(arr);System.out.println("算法4耗時:" + (System.currentTimeMillis() - t));System.out.println("結果4:" + ret4);} }

總結

以上是生活随笔為你收集整理的求最大子段和的一些算法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。