分冶算法 python代码
时间: 2023-08-30 15:02:57 浏览: 82
分治算法(Divide and Conquer Algorithm)是一种将问题分解为更小的子问题,并将这些子问题合并为原始问题的解的方法。
以下是一个使用分治算法的Python代码示例,解决传入列表nums的最大子数组和问题:
```python
def max_subarray(nums):
if len(nums) == 1:
return nums[0]
mid = len(nums) // 2
left_max = max_subarray(nums[:mid]) # 递归求左侧子数组的最大和
right_max = max_subarray(nums[mid:]) # 递归求右侧子数组的最大和
# 计算跨越中间位置的子数组的最大和
cross_max = nums[mid]
left_sum = 0
for i in range(mid-1, -1, -1): # 从中间位置向左遍历
left_sum += nums[i]
cross_max = max(cross_max, left_sum)
right_sum = 0
for i in range(mid+1, len(nums)): # 从中间位置向右遍历
right_sum += nums[i]
cross_max = max(cross_max, right_sum)
return max(left_max, right_max, cross_max) # 返回三个最大和中的最大值
# 示例调用
nums = [-2,1,-3,4,-1,2,1,-5,4]
result = max_subarray(nums)
print(result)
```
以上代码通过递归的方式将原始问题分解为更小的子问题,然后再通过合并子问题的解来获得原始问题的解。在每一次递归中,通过分别计算左侧子数组、右侧子数组和跨越中间位置的子数组的最大和,然后返回三者中的最大值。最终得到的结果即为问题的解。
阅读全文