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

学做网站看书会了吗宁德网站建设制作

学做网站看书会了吗,宁德网站建设制作,建设中网站首页,怎样卸载微信wordpress​ ​ 🔥个人主页:guoguoqiang. 🔥专栏:leetcode刷题 1.只出现一次的数字 这道题很简单,我们只需要遍历一次数组即可通过异或运算实现。(一个数与自身异或结果为0,任何数与0异或还是它本身) class Solut…


外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

🔥个人主页guoguoqiang. 🔥专栏leetcode刷题

Alt

1.只出现一次的数字

在这里插入图片描述
这道题很简单,我们只需要遍历一次数组即可通过异或运算实现。(一个数与自身异或结果为0,任何数与0异或还是它本身)

class Solution {
public:int singleNumber(vector<int>& nums) {int value=0;for(auto e:nums){value^=e;}return value;}
};

2.杨辉三角

这里是引用
这个题需要创建一个二维数组,开辟空间
vector<vector> vv , vv.resize(numRows)
在这里插入图片描述

class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> vv;vv.resize(numRows);for(int i=0;i<numRows;i++){vv[i].resize(i+1,0);vv[i][0]=vv[i][vv[i].size()-1]=1;}for(int i=0;i<numRows;i++){for(int j=0;j<i;j++){if(vv[i][j]==0){vv[i][j]=vv[i-1][j]+vv[i-1][j-1];}}}return vv;}
};

3.删除有序数组中的重复项

这里是引用
双指针,如果fast的前一个与fast相同,则对前面的值进行修改。

class Solution {
public:int removeDuplicates(vector<int>& nums) {int n=nums.size();if(n==0){return 0;}int slow=1,fast=1;while(fast<n){if(nums[fast-1]!=nums[fast]){nums[slow]=nums[fast];slow++;}fast++;}return slow;}
};

4.只出现一次的数组 二

在这里插入图片描述

//方法一 : 异或
class Solution {
public:int singleNumber(vector<int>& nums) {int ones = 0, twos = 0;       for (int num : nums) {ones = (ones ^ num) & ~twos;twos = (twos ^ num) & ~ones;}return ones;}
};
class Solution {
public:int singleNumber(vector<int>& nums) {unordered_map<int,int>freq;for(int num:nums){++freq[num];}int ans=0;for(auto [num,occ]:freq){if(occ==1){ans=num;break;}}return ans;}
};

5.只出现一次的数字 三

在这里插入图片描述

class Solution {
public:vector<int> singleNumber(vector<int>& nums) {//哈希表vector<int> ans;unordered_map<int,int>freq;for(int num:nums){++freq[num];}for(auto [num,occ]:freq){if(occ==1){ans.push_back(num);}}return ans;}
};
class Solution {
public:vector<int> singleNumber(vector<int>& nums) {// 第一步,对所有元素进行异或,最终的结果就是两个只出现一次数的异或结果int diff = 0;for (int num : nums) {diff ^= num;}// 找到diff中任何为1的位,可以使用diff & -diff快速找到// 这个操作可以隔离出diff最右端的1unsigned int diff_unsigned = diff;diff_unsigned &= -diff_unsigned;// 使用找到的这一位将数组中的数字分成两组vector<int> results(2, 0); // 最终结果for (int num : nums) {if ((num & diff_unsigned) == 0) {// 第一组,与diff_unsigned对应位为0results[0] ^= num;} else {// 第二组,与diff_unsigned对应位为1results[1] ^= num;}}return results;}
};

6.电话号码的字母组合

在这里插入图片描述

class Solution {//回溯算法。
public:vector<string> letterCombinations(string digits) {if(digits.empty()) return{};vector<string> mappings = {  // 数字到字母的映射"", "", "abc", "def",   // '0','1','2',..."ghi", "jkl", "mno","pqrs", "tuv", "wxyz"};vector<string> result;string current;backtrack(result, digits, 0, current, mappings);return result;}private:void backtrack(vector<string>& result, const string& digits, int index, string& current, const vector<string>& mappings) {if(index==digits.length()){result.push_back(current);return;}string letters = mappings[digits[index] - '0']; // 获取当前数字对应的所有字母for (char letter : letters) { // 遍历这些字母current.push_back(letter);   // 添加当前的字母backtrack(result, digits, index + 1, current, mappings);  // 继续处理下一个数字current.pop_back();  // 回溯,移除当前字母,以便尝试下一个字母}}
};
http://www.yayakq.cn/news/198223/

相关文章:

  • 灯具的网站建设海淀网站建设联系方式
  • 手机如何创建网站域名加wordpress后缀
  • 宁波网站设计价格北京 网站建设|小程序|软件开发|app开发公司
  • 创意设计一个网站静态企业网站模板
  • 企业网站色彩漳州网络推广
  • 企业网站建设套餐网络服务物业管理
  • 丹徒网站建设怎么样网站提交收录软件
  • 网站建设与维护王欣医院网站可信认证必须做吗
  • 建手机wap网站大概多少钱商标如何自己注册
  • 迅雷下载宝 做网站公司装修开工仪式需要准备什么
  • 惠州网站建设 英语全球十大it公司
  • 全国当先的网络建站推广号店网站建设公司
  • 劳务公司起名字大全免费seo网站推广杭州
  • ip网站怎么做设计制作散发寄递销售展示使用
  • 企业服务建设网站论坛推广平台有哪些
  • 电子商务网站开发过程论文6湖南省交通建设质监局网站
  • 网站后台发布文章开发一个公众号需要多少钱
  • 网站功能设计指什么wordpress-5.2.2英文转中文
  • 鸣蝉建站平台昆明好的网站开发公司
  • 个人 网站备案 幕布世界杯哪个网站做代理
  • 做数据结构基础的网站网站建设工作室
  • 网站设计说明书整合张家口网站设计
  • 网站网络营销外包检测网站开发语言
  • 网站推广有哪些常用的方法网上开店能赚钱吗
  • 免费企业网站创建网站建设的公司业务
  • 大连商城网站制作公司银川网站建设推广
  • 惠东东莞网站建设手机网站建设视频
  • 网站开发学历要求空包网网站怎么做的
  • 旅游网站建设规划报告怎么写ps网站参考线怎么做
  • 上海营销型网站代理付运费送东西的网站怎么做6