mari kita belajar bagaimana untuk mencari jumlah subarray maksimum menggunakan algoritma Kadane di Java.
Pernyataan Masalah:
Diberi pelbagai saiz n, tulis program Java untuk menentukan jumlah maksimum subarray bersebelahan menggunakan algoritma Kadane.
Contoh:
<code>Input: n = 5 arr[] = 1, 2, 3, -2, 5 Output: Maximum Subarray sum is: 9</code>
Memahami algoritma Kadane:
Algoritma Kadane menyediakan penyelesaian kerumitan masa O (n) yang cekap untuk mencari jumlah subarray maksimum.
Langkah -langkah:
- Inisialisasi dua pembolehubah:
(untuk menjejaki jumlah subarray semasa) dan
currentSum
(untuk menyimpan jumlah maksimum yang ditemui setakat ini). TetapkanmaxSum
hingga 0 dancurrentSum
ke nilai integer yang paling kecil (mis.,). maxSum
Integer.MIN_VALUE
Melangkah melalui array: Untuk setiap elemen - , tambahkan nilainya ke
.
arr[i]
currentSum
UPDATE - : Selepas setiap penambahan, kemas kini
dengan mengambil maksimum
maxSum
danmaxSum
.maxSum
currentSum
Reset - : Jika
menjadi negatif, tetapkan semula kepada 0. Ini adalah penting kerana negatif
currentSum
menunjukkan bahawa termasuk unsur -unsur sebelumnya tidak menyumbang kepada jumlah yang lebih besar; lebih baik memulakan subarray baru dari elemen semasa.currentSum
currentSum
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(); } }output (Contoh):
<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>
Atas ialah kandungan terperinci Subarray Maksimum Jawa: Algoritma Kadane. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft