回溯 Leetcode 47 全排列II

全排列II

給定一個可包含重復數字的序列 nums ,按任意順序 返回所有不重復的全排列。

Leetcode 47

學習記錄自代碼隨想錄

示例 1:
輸入:nums = [1,1,2]
輸出:
[[1,1,2],
[1,2,1],
[2,1,1]]

示例 2:
輸入:nums = [1,2,3]
輸出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

提示:
1 <= nums.length <= 8
-10 <= nums[i] <= 10

要點:1.需要兩層去重,既要樹層去重也要在同一樹枝去重;
2.可以只使用used進行樹層去重或者單獨使用used進行樹枝去重,而uset進行樹層去重;
3.組合問題和排列問題是在樹形結構的葉子節點上收集結果,而子集問題就是取樹上所有節點的結果。
4.樹層去重相比于樹枝去重較高;
在這里插入圖片描述
在這里插入圖片描述

class Solution {
private:vector<int> path;vector<vector<int>> result;void backtracking(vector<int>& nums, vector<int> used){if(path.size() == nums.size()){result.push_back(path);return;}unordered_set<int> uset;for(int i = 0; i < nums.size(); i++){// if(used[i] == 1 || (i > 0 && used[i-1] == 0 && nums[i] == nums[i-1])){//     continue;// }if(used[i] == 1 || uset.find(nums[i]) != uset.end()){continue;}uset.insert(nums[i]);used[i] = 1;path.push_back(nums[i]);backtracking(nums, used);path.pop_back();used[i] = 0;}}
public:vector<vector<int>> permuteUnique(vector<int>& nums) {path.clear();result.clear();// sort(nums.begin(), nums.end());  // 樹層去重 要排序vector<int> used(nums.size(), 0);backtracking(nums, used);return result;}
};

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

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

相關文章

Unity3d Shader篇(十)— 漸變紋理

文章目錄 前言一、什么是Unlity漸變紋理Shader&#xff1f;1. 漸變紋理Shader工作原理2. 漸變紋理&#xff1f;3. 漸變紋理的優缺點優點&#xff1a;缺點&#xff1a; 4. 漸變紋理例圖 二、使用步驟1. Shader 屬性定義2. SubShader 設置3. 渲染 Pass4. 定義結構體和頂點著色器函…

Linux下的GDB

1.前言 GDB是Linux下非常好用且強大的調試工具。GDB可以調試C、C、Go、java、 objective-c、PHP等語言。對于一名Linux下工作的c/c程序員&#xff0c;GDB是必不可少的工具 2.GDB使用幫助 GDB命令擁有較多內部命令。在gdb命令提示符下輸入help可以查看所有內部命令及使用說明 …

Mediapipe筆記:安裝Mediapipe+手部檢測+動作識別

Mediapipe 安裝Mediapipe 打開Anaconda prompt檢查環境和python運行環境是否一致(默認base環境&#xff0c;不用切換)輸入命令行pip install mediapipe0.9.1.0 -i https://pypi.tuna.tsinghua.edu.cn/simple Mediapope完成手部關鍵點檢測 手部檢測 創建對象(加載模型參數)…

(二十二)devops持續集成開發——jenkins服務代理Agent搭建

前言 在Jenkins 中&#xff0c;代理&#xff08;Agent&#xff09;是一種用于執行構建、部署和其他任務的計算節點。代理節點可以是物理機器、虛擬機或容器&#xff0c;它們負責接收 Jenkins 主控節點委派的任務并執行這些任務。通過使用代理節點&#xff0c;可以有效地分擔Je…

Redis內存淘汰策略詳解

Redis作為一個高性能的鍵值對數據庫&#xff0c;被廣泛應用于各種需要快速響應和持久存儲的場景中。然而&#xff0c;由于其內存存儲的特性&#xff0c;當Redis的內存使用達到其最大配置限制時&#xff0c;就需要有一種策略來管理內存的使用&#xff0c;以避免內存溢出。這就是…

NLP Seq2Seq模型

&#x1f368; 本文為[&#x1f517;365天深度學習訓練營學習記錄博客&#x1f366; 參考文章&#xff1a;365天深度學習訓練營&#x1f356; 原作者&#xff1a;[K同學啊 | 接輔導、項目定制]\n&#x1f680; 文章來源&#xff1a;[K同學的學習圈子](https://www.yuque.com/mi…

深入理解Linux線程(LWP):概念、結構與實現機制(2)

&#x1f3ac;慕斯主頁&#xff1a;修仙—別有洞天 ??今日夜電波&#xff1a;會いたい—Naomile 1:12━━━━━━?&#x1f49f;──────── 4:59 &#x1f504; ?? ? ?? ? &a…

Vue3+vite打包后頁面空白問題

vite.config.js vite.config.js 增加 base: ./ import { fileURLToPath, URL } from node:url import { defineConfig } from vite import vue from vitejs/plugin-vue// https://vitejs.dev/config/ export default defineConfig({base: ./,resolve: {alias: {: fileURLToPath…

解析短視頻美顏SDK:美顏美型技術的深度剖析

美顏并非簡單的濾鏡疊加&#xff0c;而是依托著先進的圖像處理和人工智能技術&#xff0c;才能夠達到如此出色的效果。本文將深入探討短視頻美顏SDK背后的技術原理和實現方法&#xff0c;從而揭示其美顏美型技術的深度剖析。 一、美顏SDK的基本原理 美顏SDK的基本原理是通過對…

maven 包管理平臺-01-maven 入門介紹 + Maven、Gradle、Ant、Ivy、Bazel 和 SBT 的詳細對比表格

拓展閱讀 maven 包管理平臺-01-maven 入門介紹 Maven、Gradle、Ant、Ivy、Bazel 和 SBT 的詳細對比表格 maven 包管理平臺-02-windows 安裝配置 mac 安裝配置 maven 包管理平臺-03-maven project maven 項目的創建入門 maven 包管理平臺-04-maven archetype 項目原型 ma…

docker單機啟動mysql、redis容器命令

將your_path、your_password、your_version替換成自己需要的 mysql docker run -d -p 3306:3306 --name mysql --restartalways \ -v /your_path/my.cnf:/etc/mysql/my.cnf \ -v /your_path/log:/logs \ -v /your_path/mysql:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORDyour_pa…

java 企業培訓管理系統Myeclipse開發mysql數據庫web結構jsp編程計算機網頁項目

一、源碼特點 java 企業培訓管理系統是一套完善的java web信息管理系統&#xff0c;對理解JSP java編程開發語言有幫助&#xff0c;系統具有完整的源代碼和數據庫&#xff0c;系統主要采用B/S模式開發。開發環境為TOMCAT7.0,Myeclipse8.5開發&#xff0c;數據庫為Mysql5.0&…

UCWSC

feature fusion neural network based on a decomposition mechanism (FFDM) 輔助信息 作者未提供代碼

學習大數據,所必需的java基礎(6)

文章目錄 集合Set集合介紹HashSet集合的介紹和使用LinkedHashSet的介紹以及使用哈希值哈希值的計算方式HashSet的存儲去重的過程 Map集合Map的介紹HashMap的介紹以及使用HashMap的兩種遍歷方式方式1&#xff1a;獲取key&#xff0c;然后再根據key獲取value方式2&#xff1a;同時…

【Sql Server】Update中的From語句,以及常見更新操作方式

歡迎來到《小5講堂》&#xff0c;大家好&#xff0c;我是全棧小5。 這是《Sql Server》系列文章&#xff0c;每篇文章將以博主理解的角度展開講解&#xff0c; 特別是針對知識點的概念進行敘說&#xff0c;大部分文章將會對這些概念進行實際例子驗證&#xff0c;以此達到加深對…

Docker技術概論(4):Docker CLI 基本用法解析

Docker技術概論&#xff08;4&#xff09; Docker CLI 基本用法解析 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:http…

Python實現PPT演示文稿中視頻的添加、替換及提取

無論是在教室、會議室還是虛擬會議中&#xff0c;PowerPoint 演示文稿都已成為一種無處不在的工具&#xff0c;用于提供具有影響力的可視化內容。PowerPoint 提供了一系列增強演示的功能&#xff0c;在其中加入視頻的功能可以大大提升整體體驗。視頻可以傳達復雜的概念、演示產…

ArkTS中的路由跳轉和HTTP數據請求

路由跳轉 步驟1&#xff1a;找到箭頭所指的文件&#xff0c;在其中添加已創建的頁面 步驟2&#xff1a;導包 步驟3&#xff1a; HTTP數據請求 步驟1&#xff1a;導包 > import http from ohos.net.http; 步驟2&#xff1a;&#xff08;如果需要在頁面加載前請求&#xf…

TcpServer服務器管理模塊(模塊十)

目錄 類功能 類定義 類實現 編譯測試 server.cc gdb測試斷點 忽略SIGPIPE信號 類功能 類定義 // TcpServer服務器管理模塊(即全部模塊的整合) class TcpServer { private:uint64_t _next_id; // 這是一個自動增長的連接IDint _port;i…

Linux學習-C語言-運算符

目錄 算術運算符&#xff1a; - * /:不能除0 %:不能對浮點數操作 &#xff1a;自增與運算符 i&#xff1a;先用再加 i:先加再用 --&#xff1a;自減運算符 常量&#xff0c;表達式不可以&#xff0c;--&#xff0c;變量可以 賦值運算符 三目運算符 逗號表達式 size…