国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁(yè) Java java教程 Java中的最大子陣列總和:Kadane的算法

Java中的最大子陣列總和:Kadane的算法

Feb 07, 2025 am 11:54 AM
java

>讓我們學(xué)習(xí)如何使用java中的kadane算法有效地找到最大子陣列總和。

問(wèn)題語(yǔ)句:

給定尺寸n的數(shù)組,編寫一個(gè)Java程序,以確定使用Kadane算法的連續(xù)子陣列的最大總和。

>示例:

<code>Input:
n = 5
arr[] = 1, 2, 3, -2, 5

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

了解Kadane的算法: Kadane的算法提供了有效的O(n)時(shí)間復(fù)雜度解決方案,以找到最大的子陣列總和。

步驟:

>初始化兩個(gè)變量:
    (跟蹤當(dāng)前子陣列的總和)和
  1. (存儲(chǔ)到目前為止遇到的最大總和)。 設(shè)置

    到0和currentSum到最小的整數(shù)值(例如,maxSum)。currentSum> maxSum Integer.MIN_VALUE

    迭代通過(guò)數(shù)組:對(duì)于每個(gè)元素
  2. ,將其值添加到
  3. >。

    > arr[i] currentSum

    > update
  4. :每次添加后,更新
  5. 最大

    maxSum>。maxSum>。 maxSum currentSum

    reset
  6. :如果
  7. 變?yōu)樨?fù)??,則將其重置為0。這很重要,因?yàn)樨?fù)

    表明包括先前的元素不會(huì)造成更大的總和;最好從當(dāng)前元素啟動(dòng)一個(gè)新的子陣列。currentSum currentSum currentSum

  8. > java代碼:

>輸出(示例):

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();
    }
}

以上是Java中的最大子陣列總和:Kadane的算法的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

Hashmap在Java內(nèi)部如何工作? Hashmap在Java內(nèi)部如何工作? Jul 15, 2025 am 03:10 AM

HashMap在Java中通過(guò)哈希表實(shí)現(xiàn)鍵值對(duì)存儲(chǔ),其核心在于快速定位數(shù)據(jù)位置。1.首先使用鍵的hashCode()方法生成哈希值,并通過(guò)位運(yùn)算轉(zhuǎn)換為數(shù)組索引;2.不同對(duì)象可能產(chǎn)生相同哈希值,導(dǎo)致沖突,此時(shí)以鏈表形式掛載節(jié)點(diǎn),JDK8后鏈表過(guò)長(zhǎng)(默認(rèn)長(zhǎng)度8)則轉(zhuǎn)為紅黑樹提升效率;3.使用自定義類作鍵時(shí)必須重寫equals()和hashCode()方法;4.HashMap動(dòng)態(tài)擴(kuò)容,當(dāng)元素?cái)?shù)超過(guò)容量乘以負(fù)載因子(默認(rèn)0.75)時(shí),擴(kuò)容并重新哈希;5.HashMap非線程安全,多線程下應(yīng)使用Concu

在C中使用std :: Chrono 在C中使用std :: Chrono Jul 15, 2025 am 01:30 AM

std::chrono在C 中用于處理時(shí)間,包括獲取當(dāng)前時(shí)間、測(cè)量執(zhí)行時(shí)間、操作時(shí)間點(diǎn)與持續(xù)時(shí)間及格式化解析時(shí)間。1.獲取當(dāng)前時(shí)間使用std::chrono::system_clock::now(),可轉(zhuǎn)換為可讀字符串但系統(tǒng)時(shí)鐘可能不單調(diào);2.測(cè)量執(zhí)行時(shí)間應(yīng)使用std::chrono::steady_clock以確保單調(diào)性,并通過(guò)duration_cast轉(zhuǎn)換為毫秒、秒等單位;3.時(shí)間點(diǎn)(time_point)和持續(xù)時(shí)間(duration)可相互操作,但需注意單位兼容性和時(shí)鐘紀(jì)元(epoch)

頂級(jí)爪哇面試問(wèn)題 頂級(jí)爪哇面試問(wèn)題 Jul 14, 2025 am 01:59 AM

Java面試高頻問(wèn)題主要集中在基礎(chǔ)語(yǔ)法、面向?qū)ο?、多線程、JVM和集合框架等方面,最常見(jiàn)的問(wèn)題包括:1.Java基本數(shù)據(jù)類型共有8種,如byte、short、int、long、float、double、char和boolean,并需注意String不是基本數(shù)據(jù)類型;2.final用于修飾類、方法或變量表示不可變,finally用于異常處理中確保代碼執(zhí)行,finalize是Object類的方法用于垃圾回收前的清理;3.多線程同步可通過(guò)synchronized關(guān)鍵字、ReentrantLock、vo

PHP準(zhǔn)備的聲明獲得結(jié)果 PHP準(zhǔn)備的聲明獲得結(jié)果 Jul 14, 2025 am 02:12 AM

在PHP中使用預(yù)處理語(yǔ)句獲取數(shù)據(jù)庫(kù)查詢結(jié)果的方法因擴(kuò)展而異,1.使用mysqli時(shí)可通過(guò)get_result()配合fetch_assoc()獲取關(guān)聯(lián)數(shù)組,適用于現(xiàn)代環(huán)境;2.也可使用bind_result()綁定變量,適合字段少、結(jié)構(gòu)固定的情況,兼容性好但字段多時(shí)較繁瑣;3.使用PDO時(shí)通過(guò)fetch(PDO::FETCH_ASSOC)獲取關(guān)聯(lián)數(shù)組,或用fetchAll()一次性獲取所有數(shù)據(jù),接口統(tǒng)一且錯(cuò)誤處理更清晰;此外需注意參數(shù)類型匹配、執(zhí)行execute()、及時(shí)釋放資源及開啟錯(cuò)誤報(bào)告以

如何使用SimpleDateFormat在Java中格式化日期? 如何使用SimpleDateFormat在Java中格式化日期? Jul 15, 2025 am 03:12 AM

創(chuàng)建并使用SimpleDateFormat需要傳入格式字符串,如newSimpleDateFormat("yyyy-MM-ddHH:mm:ss");2.注意大小寫敏感、避免混用單字母格式及YYYY和DD的誤用;3.SimpleDateFormat不是線程安全的,多線程環(huán)境下應(yīng)每次新建實(shí)例或使用ThreadLocal;4.使用parse方法解析字符串時(shí)需捕獲ParseException,并注意結(jié)果不帶時(shí)區(qū)信息;5.Java8及以上推薦使用DateTimeFormatter和Lo

GO結(jié)構(gòu)標(biāo)簽 GO結(jié)構(gòu)標(biāo)簽 Jul 14, 2025 am 02:17 AM

Go語(yǔ)言中structtags是附加在結(jié)構(gòu)體字段后的元信息,用于控制序列化、反序列化行為或提供庫(kù)配置。1.structtags以key:"value"格式寫在反引號(hào)內(nèi),如json:"name",決定字段的序列化方式;2.多個(gè)tag可共存,各庫(kù)解析所需部分,如json與gorm并用;3.mapstructure用于配置映射,支持字段名一致時(shí)省略tag及嵌套結(jié)構(gòu)體拍平;4.注意避免拼寫錯(cuò)誤、字段需導(dǎo)出、不可濫用tag影響可讀性。掌握其用法有助于提升開發(fā)效率與代

什么是Java中的雙調(diào)查器? 什么是Java中的雙調(diào)查器? Jul 14, 2025 am 02:54 AM

BiConsumer在Java中是一個(gè)函數(shù)式接口,用于處理兩個(gè)輸入?yún)?shù)且不返回結(jié)果的操作。它屬于java.util.function包,適用于需要同時(shí)操作兩個(gè)數(shù)據(jù)的場(chǎng)景,例如遍歷Map的鍵值對(duì)。常見(jiàn)用法是配合Map的forEach方法進(jìn)行迭代處理,與Consumer、BiFunction等其他函數(shù)式接口不同,BiConsumer不產(chǎn)生返回值。實(shí)現(xiàn)方式包括lambda表達(dá)式、方法引用和匿名類,使用時(shí)需注意類型參數(shù)順序、不可返回值以及異常處理等問(wèn)題。

如何為Java項(xiàng)目設(shè)置CI/CD管道? 如何為Java項(xiàng)目設(shè)置CI/CD管道? Jul 14, 2025 am 02:55 AM

TosetupaCI/CDpipelineforaJavaproject,choosetoolslikeGit,MavenorGradle,andGitHubActions,defineabranchstrategywithmainanddevelopbranches,configureCItobuildandtestusingautomation,andimplementCDfordeploymentviaSSHorDocker.1.ChooseGit,Maven/Gradle,Jenkins

See all articles