搜尋

。目標總和

Jan 02, 2025 pm 05:38 PM

. Target Sum

494。目標金額

難度:

主題:陣列、動態規劃、回溯

給你一個整數陣列 nums 和一個整數目標。

您想要透過在 nums 中的每個整數之前加上符號 ' ' 和 '-' 之一,然後連接所有整數來建立 nums 中的 表達式

  • 例如,如果 nums = [2, 1],您可以在 2 之前加上“ ”,在 1 之前加上“-”,並將它們連接起來建立表達式“ 2-1”。

傳回您可以建立的不同表達式的數量,其計算結果為目標。

範例1:

  • 輸入: nums = [1,1,1,1,1], target = 3
  • 輸出: 5
  • 說明:有 5 種分配符號的方法,使 nums 的總和為目標 3。
    • -1 1 1 1 1 = 3
    • 1 - 1 1 1 1 = 3
    • 1 1 - 1 1 1 = 3
    • 1 1 1 - 1 1 = 3
    • 1 1 1 1 - 1 = 3

範例2:

  • 輸入: nums = [1],目標 = 1
  • 輸出: 1

約束:

  • 1
  • 0
  • 0
  • -1000

解:

「目標和」問題涉及透過為每個數字分配一個或 - 符號,使用數組 nums 中的數字建立表達式。目標是計算有多少個此類表達式計算結果為給定目標。這個問題可以使用動態規劃或回溯來有效解決。

要點

  1. 輸入約束
    • 陣列長度:1
    • 元素值:0
    • 目標範圍:-1000
  2. 輸出:

    • 傳回計算結果為目標的表達式的計數。
  3. 挑戰

    • 解決方案必須同時處理較小和較大的目標值。
    • 使用回溯時有效處理多達 220 個組合。

接近

我們可以用動態規劃(子集和變換)回溯來解決這個問題。下面,我們使用動態規劃(DP)來提高效率。

主要觀察結果

  1. 如果我們將 nums 分成兩組:P(正子集)和 N(負子集),則: target = sum(P) - sum(N)

重新排列項: sum(P) sum(N) = sum(nums)

設 S 為正子集的總和。然後:S = (sum(nums) 目標) / 2

  1. 如果 (sum(nums) target) % 2 ≠ 0,則傳回 0,因為無法對總和進行分區。

計畫

  1. 計算 nums 的總和。
  2. 使用 S 公式檢查目標是否可以實現。如果無效,則回傳0。
  3. 使用 DP 方法找出 nums 中總和等於 S .
  4. 的子集的數量

讓我們用 PHP 實作這個解:494。目標金額

<?php /**
 * @param Integer[] $nums
 * @param Integer $target
 * @return Integer
 */
function findTargetSumWays($nums, $target) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example usage:
$nums = [1, 1, 1, 1, 1];
$target = 3;
echo findTargetSumWays($nums, $target); // Output: 5
?>

解釋:

  1. 輸入驗證:

    • 我們計算 S = (sum(nums) target) / 2.
    • 如果 S 不是整數,則不可能將 nums 分成兩個子集。
  2. 動態程式邏輯:

    • dp[j] 表示使用給定數字形成和 j 的方法的數量。
    • 從 dp[0] = 1 開始,對於 nums 中的每個數字,我們透過添加形成 j - num 的方式計數來更新 dp[j]。
  3. 結果

    • 處理完所有數字後,dp[S]包含達到目標總和的方法數。

範例演練

輸入: nums = [1, 1, 1, 1, 1], target = 3

  1. 總和 = 5,S = (5 3) / 2 = 4.
  2. 初始化 DP 陣列:dp = [1, 0, 0, 0, 0].
  3. 處理每個數字:
    • 對於 1:更新 dp:[1, 1, 0, 0, 0]。
    • 對於 1:更新 dp:[1, 2, 1, 0, 0]。
    • 對於 1:更新 dp:[1, 3, 3, 1, 0]。
    • 對於 1:更新 dp:[1, 4, 6, 4, 1]。
    • 對於 1:更新 dp:[1, 5, 10, 10, 5]。
  4. 結果:dp[4] = 5。

時間複雜度

  • 時間:O(n x S),其中n是nums的長度,S是目標總和。
  • 空格:DP 陣列的 O(S)。

範例輸出

輸入: nums = [1,1,1,1,1], target = 3

輸出:5

這種方法使用動態規劃有效地計算形成目標總和的方法數量。透過將問題簡化為子集和,我們利用 DP 的結構來獲得更好的效能。

聯絡連結

如果您發現本系列有幫助,請考慮在 GitHub 上給 存儲庫 一個星號或在您最喜歡的社交網絡上分享該帖子? 。您的支持對我來說意義重大!

如果您想要更多類似的有用內容,請隨時關注我:

  • 領英
  • GitHub

以上是。目標總和的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何使PHP應用程序更快如何使PHP應用程序更快May 12, 2025 am 12:12 AM

tomakephpapplicationsfaster,關注台詞:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

PHP性能優化清單:立即提高速度PHP性能優化清單:立即提高速度May 12, 2025 am 12:07 AM

到ImprovephPapplicationspeed,關注台詞:1)啟用opcodeCachingwithapCutoredUcescriptexecutiontime.2)實現databasequerycachingingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandreduceconnection.4 limitesclection.4.4

PHP依賴注入:提高代碼可檢驗性PHP依賴注入:提高代碼可檢驗性May 12, 2025 am 12:03 AM

依赖注入(DI)通过显式传递依赖关系,显著提升了PHP代码的可测试性。1)DI解耦类与具体实现,使测试和维护更灵活。2)三种类型中,构造函数注入明确表达依赖,保持状态一致。3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

PHP性能優化:數據庫查詢優化PHP性能優化:數據庫查詢優化May 12, 2025 am 12:02 AM

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

簡單指南:帶有PHP腳本的電子郵件發送簡單指南:帶有PHP腳本的電子郵件發送May 12, 2025 am 12:02 AM

phpisusedforsenderemailsduetoitsbuilt-inmail()函數andsupportivelibrariesLikePhpMailerAndSwiftMailer.1)usethemail()functionForbasiceMails,butithasimails.2)butithasimail.2)

PHP性能:識別和修復瓶頸PHP性能:識別和修復瓶頸May 11, 2025 am 12:13 AM

PHP性能瓶颈可以通过以下步骤解决:1)使用Xdebug或Blackfire进行性能分析,找出问题所在;2)优化数据库查询并使用缓存,如APCu;3)使用array_filter等高效函数优化数组操作;4)配置OPcache进行字节码缓存;5)优化前端,如减少HTTP请求和优化图片;6)持续监控和优化性能。通过这些方法,可以显著提升PHP应用的性能。

PHP的依賴注入:快速摘要PHP的依賴注入:快速摘要May 11, 2025 am 12:09 AM

依賴性注射(DI)InphpisadesignPatternthatManages和ReducesClassDeptions,增強量強制性,可驗證性和MATIALWINABIOS.ItallowSpasspassingDepentenciesLikEdenciesLikedAbaseConnectionStoclasseconnectionStoclasseSasasasasareTers,interitationAseTestingEaseTestingEaseTestingEaseTestingEasingAndScalability。

提高PHP性能:緩存策略和技術提高PHP性能:緩存策略和技術May 11, 2025 am 12:08 AM

cachingimprovesphpermenceByStorcyResultSofComputationsorqucrouctationsorquctationsorquickretrieval,reducingServerLoadAndenHancingResponsetimes.feftectivestrategiesinclude:1)opcodecaching,whereStoresCompiledSinmememorytssinmemorytoskipcompliation; 2)datacaching datacachingsingMemccachingmcachingmcachings

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版