알고리즘 서론 - 분할 알고리즘 최대 하위 배열 구하 기

2023 단어 알고리즘
알고리즘 서론 - 분할 알고리즘 최대 하위 배열 구하 기
    :            ,            。
    :

4. 567917. 가장 직관 적 인 방법 은 바로 폭력 적 으로 해결 하 는 것 이다. 즉, 이 배열 의 모든 하위 배열 을 직접 구하 고 그 중에서 최대 치 를 선택 하 는 것 이다.그러나 폭력 법의 시간 복잡 도가 비교적 높 고 O (n ^ 2) 입 니 다. 여 기 는 코드 를 붙 이지 않 습 니 다. 마침 알고리즘 을 배 웠 기 때 문 입 니 다
4. 567917. 분 치 알고리즘 에 대한 설명: 구체 적 인 사 고 는 다음 과 같다. 한 배열 의 가장 큰 서브 배열 을 구하 고 분 치 알고리즘 을 이용 하여 먼저 해 야 할 일 은 이 배열 을 두 개의 규모 가 상당 한 서브 배열 로 나 누 는 것 이다 (왜 첫 번 째 단 계 는 이것 입 니까? 구체 적 으로 분 치 알고리즘 의 정 의 를 보 는 것 입 니 다).즉, 먼저 중간 선 mid 2 를 찾 아야 한다. 두 번 째 단 계 는 두 개의 키 배열 의 가장 큰 서브 배열 을 구 하 는 것 을 고려 해 야 한다. 그러나 다른 상황 도 나타 날 수 있다. 원래 배열 의 가장 큰 서브 배열 은 시작 위치 가 mid 왼쪽 에 있 고 종료 위 치 는 mid 오른쪽 에 있다. 즉, crossmid。 3. 그러나 어쨌든 구체 적 인 상황 은 다음 과 같은 세 가지 일 수 있다. 1. 최대 하위 그룹 은 mid 왼쪽 에 있다. 2. 최대 하위 그룹 은 mid 오른쪽 에 있다. 3. crossmid
구체 적 인 사고: 재 귀 를 사용 하 다.먼저 원수 조 를 두 개의 수조 로 나 누고 끊임없이 분할 하여 최소 (즉 low = = high) 로 구분한다.이때 의 작은 배열 의 최대 왼쪽 배열 과 최대 오른쪽 배열 및 cross 를 구하 십시오.mid. 최대 치 를 이 작은 배열 의 최대 하위 배열 로 하여 계속 재 귀 합 니 다.코드 는 다음 과 같 습 니 다.
import sys
sys.setrecursionlimit(1000000)
def max_son_array(a,low,high,mid):
	left_sum=0
	right_sum=0
	left_max=0
	right_max=0
	left=mid
	right=mid
	for i in range(mid-1,low,-1):
		left_sum+=a[i]
		if left_sum>left_max :
			left_max=left_sum
			left=i
	for i in range (mid,high):
		right_sum+=a[i]
		if right_sum>right_max :
			right_max=right_sum
			right=i
		max_sum=left_max+right_max
	return (max_sum , left, right)
def find_max_array(a,low,high):
	
	if low==high:
		return (low,high,a[low])
	else:
		mid =(low+high)//2
		(l_low,l_high,l_sum)=find_max_array(a,low,mid)
		(r_low,r_high,r_sum)=find_max_array(a,mid+1,high)
		(c_sum,c_low,c_high)=max_son_array(a,low,high,mid)
		if (l_sum>=r_sum)&(l_sum>=c_sum):
			return (l_low,l_high,l_sum)
		elif (c_sum>=l_sum)&(c_sum>=r_sum):
			return (c_low,c_high,c_sum)
		else :
			return (r_low,r_high,r_sum)
aa=[13,-3,-25,20,-3,-16,-23,18,20,-7,12,-5,-22,15,-4,7]
print(find_max_array(aa,0,len(aa)-1))

좋은 웹페이지 즐겨찾기