日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Leetcode - Subsets I,II

發布時間:2025/6/17 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Leetcode - Subsets I,II 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Leetcode - 078. Subsets

這道題重定義了什么叫可行解:
一般而言,可行解需要滿足強約束性條件集,而本題的可行解就是單一弱約束性條件(distinct integers,只需要當前集合內的元素不重復即可算作一個可行解) ,算是比較簡單的入門級dfs + backtracing 題目。

class Solution { public:void dfs(vector<vector<int>> & vct,vector<int> &cur,vector<int>& nums,int index){vct.push_back(cur);int n = nums.size();if(index >= n)return;for(int i = index;i < n;++i){cur.push_back(nums[i]);dfs(vct,cur,nums,i + 1);cur.pop_back();}}vector<vector<int>> subsets(vector<int>& nums) {vector<vector<int>> vct;vector<int> cur;dfs(vct,cur,nums,0);return vct;} };

Leetcode - 090. Subsets II

diff vs the pre version:
有重復的元素怎么算?相關的思路雷同于Leetcode - 040. Combination Sum II

class Solution { public:void dfs(vector<vector<int>> &vct, vector<int> &cur, vector<int>& nums,vector<int> & used,int index){vct.push_back(cur);int n = nums.size();if (index >= n)return;for (int i = index; i < n; ++i){if (used[i] == 0){int j = i - 1;bool repeated = false;while (j >= 0 && nums[j] == nums[i]){if (used[j] == 0){repeated = true;break;}--j;}if (repeated)continue;cur.push_back(nums[i]);used[i] = 1;dfs(vct, cur, nums, used, i + 1);used[i] = 0;cur.pop_back();}}}vector<vector<int>> subsetsWithDup(vector<int>& nums) {vector<vector<int>> vct;vector<int> cur;int n = nums.size();if (n <= 0)return vct;vector<int> used(n, 0);sort(nums.begin(), nums.end());dfs(vct, cur, nums,used,0);return vct;} };

總結

以上是生活随笔為你收集整理的Leetcode - Subsets I,II的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。