力扣刷題494. 目標和

494. 目標和 - 力扣(LeetCode)

方法一,暴力dfs

直接進行深搜查找出所有的情況,缺點嚴重超時,只能過20個案例

留一下超時的

class Solution {//首先定義全局變量int[] abs = { +1, -1 };   //用來記錄當前遍歷的數的正負List<List<Integer>> list; //所有的結果List<Integer> res;         //記錄當前的結果public int findTargetSumWays(int[] nums, int target) {//初始化res = new LinkedList<>();list = new ArrayList<>();dfs(nums, target, 0, 0);return list.size();}//可直接套用dfs模版public void dfs(int[] nums, int target, int sum, int index) {//如果滿足條件則把當前的記錄加入所有的結果當中if (res.size() == nums.length && sum == target) {list.add(new ArrayList<>(res));return;}//從index進行遍歷,避免遍歷重復數據for (int i = index; i < nums.length; i++) {//遍歷數字的正負兩種情況for (int j = 0; j < 2; j++) {int x = nums[i] * abs[j];res.add(x);dfs(nums, target, sum + x, i + 1);//剪枝,移除最后的數據res.remove(res.size() - 1);}}}
}

dfs優化: 可通過

因為這一道題不需要記錄所有的方法,只需要統計一共的個數,所以可以進行優化

class Solution {//定義全局變量int count = 0;public int findTargetSumWays(int[] nums, int target) {count = 0;dfs(nums, target, 0, 0);return count;}public void dfs(int[] nums, int target, int sum, int index) {if (index == nums.length) {//這里的if不能合并,因為不管sum滿不滿足條件,都需要回溯if (sum == target) {count++;}return;}//當前數為正數dfs(nums, target, sum + nums[index], index + 1);//當前數為負數dfs(nums, target, sum - nums[index], index + 1);}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/899444.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/899444.shtml
英文地址,請注明出處:http://en.pswp.cn/news/899444.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

一周學會Flask3 Python Web開發-SQLAlchemy數據遷移migrate

鋒哥原創的Flask3 Python Web開發 Flask3視頻教程&#xff1a; 2025版 Flask3 Python web開發 視頻教程(無廢話版) 玩命更新中~_嗶哩嗶哩_bilibili 模型類(表)不是一成不變的&#xff0c;當你添加了新的模型類&#xff0c;或是在模型類中添加了新的字段&#xff0c;甚至是修改…

Python練習之抽獎界面

前言 一、代碼整體架構分析 1、數據層 (Model) 2、控制層 (Controller) 3、視圖層 (View) 二、核心功能實現詳解 1、 文件導入功能 1.1、實現邏輯 1.2、代碼涉及知識點講解 1.2.1、wildcard 1.2.2、wx.FileDialog 1.2.3、dlg.ShowModal() 2、抽獎動畫控制 1.1、…

【云原生】docker 搭建單機PostgreSQL操作詳解

目錄 一、前言 二、前置準備 2.1 服務器環境 2.2 docker環境 三、docker安裝PostgreSQL過程 3.1 獲取PostgreSQL鏡像 3.2 啟動容器 3.2.1 創建數據卷目錄 3.2.2 啟動pg容器 3.3 客戶端測試連接數據庫 四、創建數據庫與授權 4.1 進入PG容器 4.2 PG常用操作命令 4.2…

算法為舟 思想為楫:AI時代,創作何為?

在科技浪潮洶涌澎湃的當下,AI技術以前所未有的態勢席卷各個領域,創作領域亦未能幸免。當生成式AI展現出在劇本撰寫、詩歌創作、圖像設計等方面的驚人能力時,人類創作者仿佛置身于文明演化的十字路口,迷茫與困惑交織,興奮與擔憂并存。在AI時代,創作究竟該何去何從?這不僅…

JAVA的內存圖理解

目錄 一、方法區1、類常量池2、靜態常量池3、方法區過程 二、棧三、堆1、字符常量池2、堆內存圖的繪制 java中內存可以分為 方法區、 堆、 棧、 程序計數器、 本地方法棧&#xff0c;其中比較中重要的是方法區、堆、棧。 一、方法區 1.方法區&#xff08;Method Area&…

基于Selenium的IEEE Xplore論文數據爬取實戰指南

基于Selenium的IEEE Xplore論文數據爬取實戰指南 一、項目背景與目標 IEEE Xplore作為全球知名的學術資源平臺,收錄了大量高質量科技文獻。本教程將演示如何通過Python的Selenium庫實現: 自動化獲取指定領域論文列表(以"構音障礙"為例)完整提取論文標題、摘要、…

軟件工程面試題(十二)

1、文件和目錄(i/o)操作,怎么列出某目錄下所有文件?某目錄下所有子目錄,怎么判斷文件或目錄是否存在?如何讀寫文件? 列出某目錄下所有文件:調用listFile(),然后判斷每個File對象是否是文件可以調用 isFile(),判斷是否是文件夾可以調用isDirectory(),判斷文件或目…

醫療CMS高效管理:簡化更新維護流程

內容概要 醫療行業內容管理系統&#xff08;CMS&#xff09;的核心價值在于應對醫療信息管理的多維復雜性。面對診療指南的動態更新、科研數據的快速迭代以及多機構協作需求&#xff0c;傳統管理模式往往面臨效率瓶頸與合規風險。現代化醫療CMS通過構建結構化權限管理矩陣&…

談談Minor GC、Major GC和Full GC

目錄 一、背景 二、三者之間的區分 1、Minor GC 2、Major GC &#xff08;1&#xff09;老年代空間不足&#xff1a; &#xff08;2&#xff09;晉升&#xff08;Promotion&#xff09;失敗&#xff1a; &#xff08;3&#xff09;空間分配擔保失敗&#xff1a; &#x…

C盤清理技巧分享:PE Dism++ 空間清理篇

C盤清理技巧分享&#xff1a;PE & Dism 空間清理篇 C盤空間不足是許多用戶面臨的常見問題&#xff0c;尤其是在使用 Windows 系統時。本文將重點介紹如何使用 PE&#xff08;Preinstallation Environment&#xff09;和 Dism 工具高效清理 C盤空間&#xff0c;釋放寶貴的存…

低功耗LPWAN模塊開發指南:遠距離無線通信與邊緣計算融合實戰?

在遠程資產追蹤、野外環境監測等場景中&#xff0c;穩定可靠的長距離通信與超低功耗是系統設計的核心挑戰。eFish-SBC-RK3576通過 ?原生雙UART接口 USB OTG擴展能力? &#xff0c;可無縫集成主流LPWAN模組&#xff08;LoRa/NB-IoT&#xff09;&#xff0c;實現“數據采集-邊…

迅為iTOP-RK3576人工智能開發板Android 系統接口功能測試

2.1 開機啟動 開發板接通電源&#xff0c;并按下電源開關&#xff0c;系統即啟動&#xff0c;在啟動過程中&#xff0c;系統會顯示下圖中的開機畫面&#xff0c;它們分別是 Android 系統啟動時的 Logo 畫面&#xff1a; 最后會顯示如下解鎖畫面&#xff1a; 2.2 命令終端 將…

RAG基建之PDF解析的“無OCR”魔法之旅

PDF文件轉換成其他格式常常是個大難題,大量的信息被鎖在PDF里,AI應用無法直接訪問。如果能把PDF文件或其對應的圖像轉換成結構化或半結構化的機器可讀格式,那就能大大緩解這個問題,同時也能顯著增強人工智能應用的知識庫。 嘿,各位AI探險家們!今天我們將踏上了一段奇妙的…

二層框架組合實驗

實驗要求&#xff1a; 1,內網IP地址使用172.16.0.0/16分配 2,SW1和sw2之間互為備份 3,VRRP/STP/VLAN/Eth-trunk均使用 4,所有PC均通過DHCP獲取IP地址 5,ISP只能配置IP地址 6,所有電腦可以正常訪問ISP路由器環回 實驗思路順序&#xff1a; 創建vlan eth-trunk 劃分v…

光纖耦合器

以下是關于光纖耦合器的詳細介紹&#xff1a; 定義與原理 - 定義&#xff1a;光纖耦合器是一種能使傳輸中的光信號在特殊結構的耦合區發生耦合&#xff0c;并進行再分配的器件&#xff0c;也叫分歧器、連接器、適配器、光纖法蘭盤。 - 原理&#xff1a;利用不同光纖面緊鄰光纖芯…

惠普(HP)和聯想(Lenovo)作為全球兩大電腦品牌,并不是簡單的“拼接電腦”

惠普&#xff08;HP&#xff09;和聯想&#xff08;Lenovo&#xff09;作為全球兩大電腦品牌&#xff0c;并不是簡單的“拼接電腦”&#xff0c;它們都有自己的核心技術、專利設計和生態體系。以下是它們“自己的”核心部分&#xff1a; 1. 關鍵自研技術 品牌自研技術/專利說明…

若依賴前端處理后端返回的錯誤狀態碼

【背景】 后端新增加了一個過濾器&#xff0c;用來處理前端請求中的session 若依賴存放過濾器的目錄&#xff1a;RuoYi-Vue\ruoyi-framework\src\main\java\com\ruoyi\framework\security\filter\ 【問題】 后端返回了一個狀態碼為403的錯誤&#xff0c;現在前端需要處理這…

智能的數學公式:Intelligence = Priori knowledge * Reasoning ?

愛因斯坦的相對論公式大道至簡&#xff0c; 假如智能有公式的話&#xff0c;會不會是&#xff1a; 其中&#xff0c;兩個影響因子分別是先驗知識 和 推理能力&#xff0c;推理能力的指數部分可以是整數也是小數&#xff0c;但是暫時還不好確定。 解析&#xff1a;&#xff08…

簡單使用LlamaIndex實現RAG

簡單使用LlamaIndex實現RAG 1 介紹 LlamaIndex是一個專門為大語言模型&#xff08;LLM&#xff09;設計的開源數據管理工具&#xff0c;旨在簡化和優化LLM在外部數據源中的查詢過程。適合在數據索引上構建RAG。 參考的地址 # 官網地址 https://docs.llamaindex.ai/en/stabl…

Redis延時隊列在訂單超時未報到場景的應用補充說明

一、工具類設計要點解析 連接保活機制 Scheduled(cron "0 */10 * * * ?") 定時任務每10分鐘向所有隊列發送心跳消息&#xff08;"keepAlive"&#xff09;&#xff0c;避免云Redis因空閑斷開連接。這是針對云服務商自動回收空閑連接的通用解決方案1。 泛…