suchen
HeimJavajavaLernprogrammMaximale Subaarrray -Summe in Java: Kadanes Algorithmus

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:

  1. Initialisieren Sie zwei Variablen: currentSum (um die Summe des aktuellen Subtarrays zu verfolgen) und maxSum (um die bisher auftretende maximale Summe zu speichern). Setzen Sie currentSum auf 0 und maxSum auf den kleinstmöglichen Ganzzahlwert (z. B. Integer.MIN_VALUE).

  2. durch das Array iterieren: Fügen Sie für jedes Element arr[i] seinen Wert zu currentSum.

    hinzu
  3. update maxSum: Aktualisieren Sie nach jeder Hinzufügung maxSum, indem Sie das Maximum von maxSum und currentSum.

  4. Zurücksetzen

    : Wenn currentSum negativ wird, setzen Sie es auf 0 zurück. Dies ist entscheidend, da ein negativer currentSum 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>

Maximum Subarray Sum in Java: Kadane’s Algorithm

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!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SecLists

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

PHPStorm Mac-Version

Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung