Lassen Sie uns lernen, wie Sie die maximale Subaarrray -Summe mit Kadanes Algorithmus in Java effizient finden.
Problemanweisung:
Schreiben Sie ein Java -Programm, um die maximale Summe eines zusammenhängenden Subarrays mit dem Algorithmus von Kadane zu bestimmen.
Beispiel:
<code>Input: n = 5 arr[] = 1, 2, 3, -2, 5 Output: Maximum Subarray sum is: 9</code>
Kadanes Algorithmus verstehen:
Kadanes Algorithmus liefert eine effiziente O (N) -Komplexitätslösung für die Ermittlung der maximalen Subare -Summe.
Schritte:
-
Initialisieren Sie zwei Variablen:
currentSum
(um die Summe des aktuellen Subtarrays zu verfolgen) undmaxSum
(um die bisher auftretende maximale Summe zu speichern). Setzen SiecurrentSum
auf 0 undmaxSum
auf den kleinstmöglichen Ganzzahlwert (z. B.Integer.MIN_VALUE
). -
durch das Array iterieren: Fügen Sie für jedes Element
hinzuarr[i]
seinen Wert zucurrentSum
. -
update
maxSum
: Aktualisieren Sie nach jeder HinzufügungmaxSum
, indem Sie das Maximum vonmaxSum
undcurrentSum
. - Zurücksetzen
: Wenn
currentSum
negativ wird, setzen Sie es auf 0 zurück. Dies ist entscheidend, da ein negativercurrentSum
angibt, dass die Einbeziehung der vorherigen Elemente nicht zu einer größeren Summe beiträgt. Es ist besser, ein neues Subtarray aus dem aktuellen Element zu starten.currentSum
Java -Code:
import java.util.Scanner; public class KadaneAlgo { public static int findMaxSubArraySum(int[] arr, int n) { int currentSum = 0; int maxSum = Integer.MIN_VALUE; // Initialize to the smallest possible integer for (int i = 0; i < n; i++) { currentSum += arr[i]; maxSum = Math.max(maxSum, currentSum); // Update maxSum if necessary if (currentSum < 0) { currentSum = 0; // Reset currentSum if it becomes negative } } return maxSum; } public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.print("Enter the size of the array: "); int n = scanner.nextInt(); int[] arr = new int[n]; System.out.print("Enter the elements of the array: "); for (int i = 0; i < n; i++) { arr[i] = scanner.nextInt(); } int maxSum = findMaxSubArraySum(arr, n); System.out.println("Maximum Subarray sum is: " + maxSum); scanner.close(); } }
Ausgabe (Beispiel):
<code>Enter the size of the array: 5 Enter the elements of the array: 1 2 3 -2 5 Maximum Subarray sum is: 9</code>
Das obige ist der detaillierte Inhalt vonMaximale Subaarrray -Summe in Java: Kadanes Algorithmus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung