当前位置: 首页 > news >正文

东莞做网站费用打电话说帮忙做网站

东莞做网站费用,打电话说帮忙做网站,安徽网络优化方案,关于建设工程的网站文章目录 1、全排列2、子集3、找出所有子集的异或总和再求和4、全排列 II5、电话号码的字母组合6、括号生成 1、全排列 给定一个不含重复数字的数组 nums &#xff0c;返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 class Solution { public:vector<vector<i…

文章目录

  • 1、全排列
  • 2、子集
  • 3、找出所有子集的异或总和再求和
  • 4、全排列 II
  • 5、电话号码的字母组合
  • 6、括号生成

1、全排列

给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。
在这里插入图片描述

class Solution {
public:vector<vector<int>> ret;vector<int> path;//vector<bool> sign(7);并不能使用它,它并不能使用[],底层储存问题bool sign[7];vector<vector<int>> permute(vector<int>& nums) {dfs(nums);return ret;}void dfs(vector<int>& nums){if(nums.size()==path.size()){ret.push_back(path);return;}for(int i=0;i<nums.size();i++){if(sign[i]==false){path.push_back(nums[i]);sign[i]=true;dfs(nums);path.pop_back();sign[i]=false;}}}
};

2、子集

给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的
子集(幂集)。
解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
在这里插入图片描述

class Solution {
public:vector<vector<int>> ret;vector<int> path;vector<vector<int>> subsets(vector<int>& nums) {dfs(nums,0);return ret;}//解法一// void dfs1(vector<int> nums,int i)// {//     if(i==nums.size())//     {//         ret.push_back(path);//         return;//     }//     //选//     path.push_back(nums[i]);//     dfs(nums,i+1);//     path.pop_back();//     //不选//     dfs(nums,i+1);// }//解法二void dfs(vector<int> nums,int pos){ret.push_back(path);for(int i=pos;i<nums.size();i++){path.push_back(nums[i]);dfs(nums,i+1);path.pop_back();}}
};

3、找出所有子集的异或总和再求和

一个数组的 异或总和 定义为数组中所有元素按位 XOR 的结果;如果数组为 空 ,则异或总和为 0 。
例如,数组 [2,5,6] 的 异或总和 为 2 XOR 5 XOR 6 = 1 。
给你一个数组 nums ,请你求出 nums 中每个 子集 的 异或总和 ,计算并返回这些值相加之 和 。
注意:在本题中,元素 相同 的不同子集应 多次 计数。
数组 a 是数组 b 的一个 子集 的前提条件是:从 b 删除几个(也可能不删除)元素能够得到 a 。
在这里插入图片描述

class Solution {
public:// vector<int> ret;// vector<int> path;// int subsetXORSum(vector<int>& nums) {//     dfs(nums,0);//     int sum=0;//     for(int i=0;i<ret.size();i++)//     {//         sum+=ret[i];//     }//     return sum;// }// void dfs(vector<int> nums,int pos)// {//     int sum=0;//     for(int i=0;i<path.size();i++)//     {//         sum^=path[i];//     }//     ret.push_back(sum);//     for(int i=pos;i<nums.size();i++)//     {//         path.push_back(nums[i]);//         dfs(nums,i+1);//         path.pop_back();//     }// }int sum=0;int path=0;int subsetXORSum(vector<int> nums){dfs(nums,0);return sum;}void dfs(vector<int> nums,int pos){sum+=path;//每次开始的节点都是我们需要的for(int i=pos;i<nums.size();i++){path^=nums[i];dfs(nums,i+1);path^=nums[i];//恢复现场}}
};

4、全排列 II

给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列。
在这里插入图片描述

class Solution {
public:vector<vector<int>> ret;vector<int> path;bool check[8];vector<vector<int>> permuteUnique(vector<int>& nums) {sort(nums.begin(),nums.end());//方便后面处理分支dfs(nums,0);return ret;}void dfs(vector<int> nums,int pos){if(pos==nums.size())ret.push_back(path);for(int i=0;i<nums.size();i++){//剪枝方法一,只关心合法分支// if(check[i]==false&&(i==0||nums[i]!=nums[i-1]||(check[i-1]==true&&nums[i]==nums[i-1])))// {//     check[i]=true;//     path.push_back(nums[i]);//     dfs(nums,pos+1);//     check[i]=false;//     path.pop_back();// }//剪枝方法二,只关心不合法分支if(check[i]==true||(i!=0&&nums[i]==nums[i-1]&&check[i-1]==false))continue;check[i]=true;path.push_back(nums[i]);dfs(nums,pos+1);check[i]=false;path.pop_back();}}
};

5、电话号码的字母组合

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
在这里插入图片描述


class Solution {
public:string hash[10]={"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};vector<string> ret;string path;vector<string> letterCombinations(string digits) {if(digits.empty())return ret;dfs(digits,0);return ret;}void dfs(string digits,int pos){if(pos==digits.size()){ret.push_back(path);return;}for(auto a : hash[digits[pos]-'0']){path.push_back(a);dfs(digits,pos+1);path.pop_back();}}
};

6、括号生成

数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。
在这里插入图片描述

class Solution {
public:int left,right,n;vector<string> ret;string path;vector<string> generateParenthesis(int _n) {n=_n;dfs();return ret;}void dfs(){if(right==n){ret.push_back(path);return;}if(left<n){path.push_back('(');left++;dfs();path.pop_back();left--;}if(right<left){path.push_back(')');right++;dfs();path.pop_back();right--;}}
};
http://www.yayakq.cn/news/653815/

相关文章:

  • 众筹平台网站建设自己怎么做单页网站
  • 如何搭建一个网站平台宁波网站制作公司排名
  • 做的网站兴义网站seo
  • 开源网站管理系统自定义wordpress背景图
  • 网站响应式图片切换代码广告艺术设计学什么
  • 南昌建设局萍乡网站seo
  • 昌乐哪里有做网站的海南公共招聘网
  • 如何推广企业网站中国装饰公司十大排名
  • 做茶叶网站的目的和规划企业网站的新闻资讯版块有哪些
  • 国内团购网站做的最好的是o2o电子商务模式
  • 网站是用dreamer做的_为什么后台能进去前台进不去了wordpress企业模板中文
  • 重庆住建网站眼科医院网站设计怎么做6
  • 手机网站设计与实现是什么wordpress英文
  • 重点建设专业 专题网站怎么做子网站
  • 网站开发语言的选择江都建设银行网站
  • 网站运营与管理实训报告wordpress 监测插件
  • 国外高清视频素材网站推荐wordpress 无法安装插件
  • 成都工信部网站如何建立自己的网页
  • 庭院设计网站推荐品牌网站建设熊掌号
  • 长沙娱乐网站开发服装设计参考网站
  • 广西住房与城乡建设部网站英涛祛斑 网站开发
  • 网站网站开发设计青岛网站设计公司
  • 做黑彩网站图片wordpress 数据库设置密码
  • 山西省住房和城乡建设厅官方网站常做网站首页的文件名
  • 接单做网站wordpress 在线手册
  • 路由器屏蔽网站怎么做谷歌海外推广怎么做
  • 领域网站建设西安市发布最新消息
  • 微信网站案例济南软件优化网站
  • 广东企业建网站塘厦高铁站
  • 网站建设加网络营销北京公司注册中介正规