分治算法 例子
给定一个数组,找出组内元素相加值最大的子数组, 子数组元素由 给定数组的连续元素组成,子数组长度 在 1 和 给定数组的长度之间。
#include <iostream> #include <climits> using namespace std; // 返回两个数中的最大值 int max(int a, int b) { return (a > b) ? a : b; } // 返回三个数中的最大值 int max(int a, int b, int c) { return max(max(a, b), c); } // 计算跨越中点的最大子数组和 参数说明: arr 是数组名 、 l 是数组左边界、 m 是中间 、 h 是右边界 int maxCrossingSum(int arr[], int l, int m, int h) { int sum = 0; int left_sum = INT_MIN; cout << "INT_MIN is : "<<INT_MIN << endl; for (int i = m; i >= l; i--) { sum = sum + arr[i]; if (sum > left_sum) { left_sum = sum; } } sum = 0; int right_sum = INT_MIN; for (int i = m + 1; i <= h; i++) { sum = sum + arr[i]; if (sum > right_sum) { right_sum = sum; } } return left_sum + right_sum; } // 计算最大子数组和 参数说明: arr 是数组名、l 是数组左边界 、 h 是数组右边界 int maxSubArraySum(int arr[], int l, int h) { if (l == h) { return arr[l]; } int m = (l + h) / 2; return max(maxSubArraySum(arr, l, m), maxSubArraySum(arr, m + 1, h), maxCrossingSum(arr, l, m, h)); } int main() { int arr[] = { 2, -5, 4, -2, 1, -3, 5, -6 }; int n = sizeof(arr) / sizeof(arr[0]); int max_sum = maxSubArraySum(arr, 0, n - 1); cout << "Maximum contiguous sum is " << max_sum << endl; return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具