>Java >java지도 시간 >Java의 최대 서브 어레이 합계 : Kadane의 알고리즘

Java의 최대 서브 어레이 합계 : Kadane의 알고리즘

Barbara Streisand
Barbara Streisand원래의
2025-02-07 11:54:19717검색
Java에서 Kadane의 알고리즘을 사용하여 최대 서브 어레이 합계를 효율적으로 찾는 방법을 배우자. 문제 설명 :

크기 N 배열 N이 주어지면 Kadane의 알고리즘을 사용하여 연속 서브 어레이의 최대 합을 결정하기 위해 Java 프로그램을 작성하십시오. 예 :

Kadane의 알고리즘 이해 : Kadane의 알고리즘은 최대 서브 어레이 합계를 찾기위한 효율적인 O (n) 시간 복잡성 솔루션을 제공합니다.

단계 :

두 변수를 초기화합니다. 가능한 가장 작은 정수 값 (예 : )으로 를 0으로,

를 설정하십시오. 배열을 통해 반복 : 각 요소에 대해

에 값을 추가하십시오.
<code>Input:
n = 5
arr[] = 1, 2, 3, -2, 5

Output:
Maximum Subarray sum is: 9</code>

update : 각 추가 후 를 취득하여

를 업데이트하십시오.

리셋 : 가 음수가되면 0으로 재설정하십시오. 이는 이전 요소를 포함하는 것이 더 큰 합에 기여하지 않기 때문에 중요합니다. 현재 요소에서 새 서브 어레이를 시작하는 것이 좋습니다.

  1. Java 코드 :

    currentSum maxSum 출력 (예) : currentSum maxSum Integer.MIN_VALUE

위 내용은 Java의 최대 서브 어레이 합계 : Kadane의 알고리즘의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.