代碼隨想錄訓練營第二十四天 78子集 90子集II

第一題:

原題鏈接:78. 子集 - 力扣(LeetCode)

思路:

本題很簡單,就是在每次遍歷的地方都要搜集結果。

終止條件:當前要收集的起始位置已經大于等于數組的大小的時候證明已經搜集到完成了。

代碼如下:

class Solution {
public:vector<vector<int>> subsets(vector<int>& nums) {backtracking(nums, 0);return res;}
private:vector<vector<int>> res;vector<int> path;void backtracking(vector<int>& nums, int startIndex){res.push_back(path);if(startIndex >= nums.size()){return;}for(int i = startIndex; i < nums.size(); i++){path.push_back(nums[i]);backtracking(nums, i + 1);path.pop_back();}}
};

第二題:

原題鏈接:90. 子集 II - 力扣(LeetCode)

思路:

本題和子集很相似,但是要注意的是本題有重復的元素,但是結果中不能包含重復的子集。

和之前的一道題很相似40. 組合總和 II - 力扣(LeetCode),都是樹層和樹枝去重的邏輯。

用一個bool類型的數據來記錄當前元素是否被遍歷過。

carl說也可以不用使用bool類型的數組記錄,因為遞歸的時候下一個startIndex是i+1而不是0。如果要是全排列的話,每次要從0開始遍歷,為了跳過已入棧的元素,需要使用used。

這題一開始要進行排序才行。

代碼如下:

class Solution {
public:vector<vector<int>> subsetsWithDup(vector<int>& nums) {vector<bool> used(nums.size(), false);sort(nums.begin(), nums.end());backtracking(nums, 0, used);return res;}
private:vector<vector<int>> res;vector<int> path;void backtracking(vector<int>& nums, int startIndex, vector<bool> used){res.push_back(path);for(int i = startIndex; i < nums.size(); i++){if(i > 0 && nums[i] == nums[i - 1] && used[i - 1] == false) continue;path.push_back(nums[i]);used[i] = true;backtracking(nums, i + 1, used);used[i] = false;path.pop_back();}}
};

第三題:

原題鏈接:93. 復原 IP 地址 - 力扣(LeetCode)

思路:

終止條件:

用一個count值來記錄當前遍歷到IP地址的第幾個字段了,如果當前已經遍歷到第三個字段的時候,就需要考慮剩下的字符是否符合要求,如果符合要求的話就將剩下的結果添加到path中,如何將path添加到res結果數組中。接下來是重點,這里需要回溯,我因為沒有回溯出現了很大的問題。

在for循環中就是判斷當前截取的字符串是否符合要求,如果符合要求的話就將該字符串添加到path路徑中同時添加一個“.”,然后count++;接著就是遞歸加回溯。

回溯的話要注意pop掉你添加進去的,不能只pop一次。

在判斷是否符合IP字段要求的函數中需要注意,有一個@字符需要判斷。然后用sum來記錄所有當前字段的int值并進行判斷。我使用stoi函數失敗了。

代碼如下:

class Solution {
public:vector<string> restoreIpAddresses(string s) {backtracking(s, 0, 0);return res;}
private:vector<string> res;string path;void backtracking(string s, int startIndex, int count){if(count == 3){if(isIP(s, startIndex, s.size() - 1)){path += s.substr(startIndex, s.size() - 1 - startIndex + 1);res.push_back(path);// 回溯for(int i = 0; i < s.size() - startIndex; i++) {path.pop_back();}return;return;}}for(int i = startIndex; i < s.size(); i++){if(isIP(s, startIndex, i)){string st = s.substr(startIndex, i - startIndex + 1);int size = st.size();path += st;path += ".";count += 1;backtracking(s, i + 1, count);count -= 1;path.pop_back();while(size){path.pop_back();size--;}}}}bool isIP(const string& s, int start, int end){if(start > end) return false;if(start != end && s[start] == '0') return false;int sum = 0;for(int i = start; i <= end; i++){if(s[i] == '@')return false;else{sum = sum * 10 + (s[i] - '0');}if(sum > 255){return false;}}return true;}
};

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

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

相關文章

Foxit Reader(福昕閱讀器)詳細安裝和使用教程

第一部分&#xff1a;Foxit Reader簡介和基本信息 1.1 什么是Foxit Reader&#xff1f; Foxit Reader&#xff08;福昕閱讀器&#xff09;是一款功能強大的PDF閱讀和編輯軟件&#xff0c;以其快速、輕巧和豐富的功能而聞名。它不僅支持常規的PDF閱讀功能&#xff0c;還提供了…

LeetCode刷題之HOT100之最大正方形

今天下起了暴雨&#xff0c;本以為下午就可以結束的答辯又因為老師開會被推遲。研三的學長走了后我們開始了0元購&#xff0c;收獲頗豐哈哈&#xff0c;做個題 1、題目描述 2、算法分析 給定一個矩形&#xff0c;要求最大正方形。第一次見這種題目哈 2024 6/30 嘿嘿&#xff…

實體零售連鎖企業如何通過物流接口實現數智化轉型升級?

在電子商務浪潮的持續沖擊下&#xff0c;傳統的實體零售行業面臨著巨大的挑戰。為了在線上線下融合的新零售時代保持競爭力&#xff0c;眾多實體零售企業積極尋求數字化轉型的突破。 某中國零售連鎖百強企業近年來致力于打造自有品牌的線上銷售體系&#xff0c;自2021年8月起接…

深入解析 gRPC 的重連機制

目錄 什么是 gRPC 重連機制 gRPC 重連策略 gRPC 重連參數 gRPC 重連機制原理 重連機制的注意事項 小結 gRPC 的重連機制是確保客戶端在連接斷開后能夠自動重新連接到服務器的一種機制&#xff0c;對于分布式系統和微服務架構中的高可用性和容錯性至關重要。 什么是 gRPC…

Python數據分析-風濕關節炎生存分析

一、研究背景和意義 類風濕關節炎&#xff08;RA&#xff09;是一種慢性炎癥性疾病&#xff0c;主要影響關節&#xff0c;但也可能影響身體的其他部分。RA的病因尚不完全清楚&#xff0c;但已知其涉及免疫系統的異常反應。患者的免疫系統錯誤地攻擊自身的關節組織&#xff0c;…

HCIA4.9-4.19筆記

通訊——雙向的&#xff0c;必須保證有來有回才能成功。 當拓撲圖中的所有路由器擁有拓撲圖中的所有網段時&#xff0c;即可實現全網通。 路由器獲取位置網段的方法 靜態路由 由管理員手寫的路由條目 動態路由 所有路由器上運行同一種動態路由協議&#xff0c;之后通過路…

Python 3 注釋

Python 3 注釋 在編程中,注釋是一種用于解釋代碼和提供上下文的方式,它對代碼的執行沒有影響。Python 3 支持多種類型的注釋,包括單行注釋和多行注釋。注釋對于提高代碼的可讀性和維護性非常重要,特別是在團隊合作和大型項目中。 單行注釋 單行注釋以井號(#)開頭,用于…

C++ 成員模板類

#include <iostream> // 包含頭文件。 using namespace std; // 指定缺省的命名空間。template<class T1, class T2> class AA // 類模板AA。 { public:T1 m_x;T2 m_y;AA(const T1 x, const T2 y) : m_x(x), m_y(y) {}void show() { c…

Python 學習之簡單的程序(三)

編寫簡單的Python程序是鞏固基礎的好方法。下面我將給出幾個簡單的Python程序示例&#xff0c;涵蓋了基本的數據類型、控制流、函數和文件操作。 示例1&#xff1a;Hello, World! 這是最簡單的Python程序&#xff0c;用于打印出 "Hello, World!"。 print("He…

初學者指南:如何選擇嵌入式Linux和單片機(MCU)

前言 在嵌入式系統開發領域&#xff0c;選擇合適的平臺是項目成功的關鍵之一。對于初學者來說&#xff0c;如何在嵌入式Linux和單片機&#xff08;MCU&#xff09;之間做出選擇可能是一項艱巨的任務。本文將詳細解釋這兩種平臺的特點、優缺點&#xff0c;以及在不同應用場景中…

低代碼表單配置平臺替代普通表單配置平臺,前端部分重構的設計和思路

前言 最近將公司的舊表單配置平臺重構為低代碼表單配置平臺&#xff0c;這里記錄一下這個過程的設計和思路&#xff0c;不涉及具體的代碼&#xff1b;另外這篇文章基本只涉及前端部分&#xff0c;也不涉及與后端數據交互部分。 需求 固化的表單配置平臺 -> 靈活的表單配置…

TreeMap 和 TreeSet 的基本情況、特性以及使用場景,并對比它們與 HashMap 和 HashSet

TreeMap 基本情況 實現&#xff1a;基于紅黑樹實現的 NavigableMap。排序&#xff1a;鍵按自然順序或自定義順序&#xff08;通過 Comparator&#xff09;排序。特性&#xff1a; 不允許 null 鍵&#xff0c;但允許 null 值。保證鍵有序。迭代時按排序順序。復雜度&#xff1…

【最長公共前綴 動態規劃】2430. 對字母串可執行的最大刪除數

如果有不明白的&#xff0c;請加文末QQ群。 本文涉及知識點 最長公共前綴 動態規劃 動態規劃匯總 LeetCode 2430. 對字母串可執行的最大刪除數 給你一個僅由小寫英文字母組成的字符串 s 。在一步操作中&#xff0c;你可以&#xff1a; 刪除 整個字符串 s &#xff0c;或者 …

vscode中的字符縮進問題

問題描述&#xff1a; 如圖當一行代碼中出現不同類型的字符時&#xff0c;使用tab縮只是插入了固定數量&#xff08;默認4&#xff09;的空格或制表符&#xff0c;仍然無法對齊。 解決方法&#xff1a; vscode找到設置&#xff0c;搜索fontFamily&#xff0c;對應輸入框寫入mon…

Linux系統編程--進程間通信

目錄 1. 介紹 1.1 進程間通信的目的 1.2 進程間通信的分類 2. 管道 2.1 什么是管道 2.2 匿名管道 2.2.1 接口 2.2.2 步驟--以父子進程通信為例 2.2.3 站在文件描述符角度-深度理解 2.2.4 管道代碼 2.2.5 讀寫特征 2.2.6 管道特征 2.3 命名管道 2.3.1 接口 2.3.2…

集成平臺建設方案(Doc原件)

基礎支撐平臺作為系統總體架構的核心&#xff0c;不僅要促進與各應用子系統和第三方系統的順暢交互&#xff0c;還需確保內部業務在該平臺上能夠靈活擴展。針對這一需求&#xff0c;我們對基礎支撐平臺提出了以下要求&#xff1a; (1) 平臺需基于其基礎架構&#xff0c;為多源異…

python基礎:設置代碼格式

隨著編寫的程序越來越長&#xff0c;有必要了解一些代碼格式的約定&#xff0c;讓你的代碼盡可以能易于閱讀。 python代碼編寫規范為PEP8&#xff0c;有興趣的朋友可以下載觀看&#xff0c;這里僅作簡要說明。 1、縮進 PEP8建議每級縮進都使用4個空格。多數情況下編程語言的…

vscode-創建vue3項目-修改暗黑主題-常見錯誤-element插件標簽-用法涉及問題

文章目錄 1.vscode創建運行編譯vue3項目2.添加項目資源3.添加element-plus元素4.修改為暗黑主題4.1.在main.js主文件中引入暗黑樣式4.2.添加自定義樣式文件4.3.html頁面html標簽添加樣式 5.常見錯誤5.1.未使用變量5.2.關閉typescript檢查5.3.調試器支持5.4.允許未到達代碼和未定…

UE5的安裝與基本操作(一)

文章目錄 前言安裝UE5新建第一個游戲項目基本游覽方式對目標進行變換各種變換對齊 快速定位目標 總結 前言 Unreal Engine 5 (UE5) 是一款由 Epic Games 開發的實時 3D 創作平臺&#xff0c;用于制作游戲、電影、動畫、建筑可視化和其他類型的交互式體驗。UE5 提供了一系列強大…

Flutter第十五彈 Flutter插件

目標&#xff1a; 1.Flutter插件是什么&#xff1f;有什么作用&#xff1f; 插件 (plugin) 是 package 的一種&#xff0c;全稱是 plugin package&#xff0c;我們簡稱為 plugin&#xff0c;中文叫插件。 2.怎么創建Flutter插件&#xff1f; 一、什么是插件 在flutter中&am…