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

两学一做纪实评价系统登陆网站淘宝推广软件

两学一做纪实评价系统登陆网站,淘宝推广软件,苏州兼职网站开发,夏家胡同网站建设哈希 128.最长连续序列 128. 最长连续序列 - 力扣(LeetCode) 这个题要求O(n)的时间复杂度,我一开始想的是双指针算法(因为我并不是很熟悉set容器的使用),但是双指针算法有小部分数据过不了。 题解给的哈…

哈希

128.最长连续序列

128. 最长连续序列 - 力扣(LeetCode)

这个题要求O(n)的时间复杂度,我一开始想的是双指针算法(因为我并不是很熟悉set容器的使用),但是双指针算法有小部分数据过不了。

题解给的哈希算法太妙了,简单来说就是通过unordered_set来去重,然后对于序列中的每一个元素num,使用count操作来查找序列中是否存在num-1,不存在的话,说明这个元素num是连续序列的首元素,最后比较得到最大值就行。

 set、multiset、map、multimap
特点:底层是红黑树,键值有序,set 、 map 键不可重复,multiset 和 multimap 可重复;
复杂度:插入、删除、查找都为O(logN);

unordered_set,unordered_map,unordered_multiset,unordered_multimap
特点:底层实现是哈希表,键值无序,unordered_set 和 unordered_map 键不可重复,而另外两个可以重复;
复杂度:插入、删除、查找平均为O(1),最坏为O(N),空间换时间;

C++代码 

class Solution {
public:int longestConsecutive(vector<int>& nums) {unordered_set<int>num_set;for(auto &num:nums)num_set.insert(num);int ans=0;for(auto &num:num_set){if(num_set.count(num-1)==0){int cur=num;int curans=1;while(num_set.count(cur+1)){cur+=1;curans+=1;}ans=max(ans,curans);}}return ans;}
};

python代码

class Solution:def longestConsecutive(self, nums: List[int]) -> int:ans=0num_set=set(nums)for num in num_set:if num-1 not in num_set:cur_num=numcur_ans=1while cur_num+1 in num_set:cur_num+=1cur_ans+=1ans=max(ans,cur_ans)return ans

 双指针

283.移动零

283. 移动零 - 力扣(LeetCode)

方法一:用双指针算法把非0的元素移动到前面去,最后补0

class Solution {
public:void moveZeroes(vector<int>& nums) {int j=0;for(int i=0;i<nums.size();i++){if(nums[i]){nums[j++]=nums[i];}}for(int i=j;i<nums.size();i++){nums[i]=0;}}
};

 方法二:我也不知道题解怎么想出来的

class Solution {
public:void moveZeroes(vector<int>& nums) {int j=0;for(int i=0;i<nums.size();i++){if(nums[i]){int temp=nums[i];nums[i]=nums[j];nums[j]=temp;j++;}}}
};

python代码

class Solution:def moveZeroes(self, nums: List[int]) -> None:"""Do not return anything, modify nums in-place instead."""j=0for i in range(len(nums)):if nums[i]:nums[j],nums[i]=nums[i],nums[j]j+=1

11.盛最多水的容器 

11. 盛最多水的容器 - 力扣(LeetCode)

 这道题的最优解法是左右双指针法。双指针法的难点在于难于想到,难以证明。

 AcWing 1575. 从暴力优化到双指针,明明白白(图解) - AcWing

 移动短的一边是因为:如果移动长的一边,宽已经由短的一边固定了,长度在不断缩减,所以以后的面积只会比现在小;如果移动短的一边,即使长度变短了,但是宽度和长度的乘积可能会变大;最后就是将最大值返回

class Solution {
public:int maxArea(vector<int>& height) {int ans=-1;int i=0,j=height.size()-1;while(i!=j){ans=max(ans,(j-i)*min(height[i],height[j]));if(height[i]<height[j])i++;else j--;}return ans;}
};

python

class Solution:def maxArea(self, height: List[int]) -> int:ans=-1i=0j=len(height)-1while(i!=j):ans=max(ans,(j-i)*min(height[i],height[j]))if(height[i]<height[j]):i+=1else:j-=1return ans

 15.三数之和

15. 三数之和 - 力扣(LeetCode)

  1. 排序:使用std::sort对数组进行排序。
  2. 外层循环:从第一个元素开始,每次选择一个元素作为三元组的第一个数。
  3. 内层循环:使用两个指针leftright从中间开始向两边扩展,寻找和为0的三元组。
  4. 跳过重复元素:在添加三元组到结果数组之前,检查当前元素是否与前一个元素相同,如果是,则跳过当前元素,避免重复。

定一找二,变双指针

class Solution {
public:vector<vector<int>> threeSum(vector<int>& nums) {std::sort(nums.begin(), nums.end());vector<vector<int>> ans;int n = nums.size();for (int i = 0; i < n - 2; i++) {if (i && nums[i] == nums[i - 1]) continue; // 跳过重复的元素int left = i + 1, right = n - 1;while (left < right) {long long sum = nums[i] + nums[left] + nums[right];if (sum == 0) {ans.push_back({nums[i], nums[left], nums[right]});while (left < right && nums[left] == nums[left + 1]) left++; // 跳过重复的元素while (left < right && nums[right] == nums[right - 1]) right--; // 跳过重复的元素left++;right--;} else if (sum < 0) {left++;} else {right--;}}}return ans;}
};


文章转载自:
http://dinncopantler.wbqt.cn
http://dinnconatatorial.wbqt.cn
http://dinncorevenue.wbqt.cn
http://dinncobenzomorphan.wbqt.cn
http://dinncongwee.wbqt.cn
http://dinncosphingolipide.wbqt.cn
http://dinncogenocidist.wbqt.cn
http://dinncodeterrent.wbqt.cn
http://dinnconixy.wbqt.cn
http://dinncoleeboard.wbqt.cn
http://dinncofirkin.wbqt.cn
http://dinncodeproletarianize.wbqt.cn
http://dinncoplantimal.wbqt.cn
http://dinncoinventory.wbqt.cn
http://dinncomoider.wbqt.cn
http://dinncosempre.wbqt.cn
http://dinncopantomime.wbqt.cn
http://dinncophenetole.wbqt.cn
http://dinncohushaby.wbqt.cn
http://dinncosoul.wbqt.cn
http://dinncobrassiness.wbqt.cn
http://dinncobantering.wbqt.cn
http://dinncoorogenesis.wbqt.cn
http://dinncolowermost.wbqt.cn
http://dinncolongeval.wbqt.cn
http://dinncopurbeck.wbqt.cn
http://dinncofio.wbqt.cn
http://dinncoearthing.wbqt.cn
http://dinncomormon.wbqt.cn
http://dinncodryest.wbqt.cn
http://dinncooscillation.wbqt.cn
http://dinncoepistolography.wbqt.cn
http://dinncolikuta.wbqt.cn
http://dinncoflaked.wbqt.cn
http://dinncodesuetude.wbqt.cn
http://dinncomome.wbqt.cn
http://dinncoclotheshorse.wbqt.cn
http://dinncohyena.wbqt.cn
http://dinncopettifogger.wbqt.cn
http://dinncosluit.wbqt.cn
http://dinncoflop.wbqt.cn
http://dinncopomposo.wbqt.cn
http://dinncotrotter.wbqt.cn
http://dinncotick.wbqt.cn
http://dinncoflagelliform.wbqt.cn
http://dinncovertex.wbqt.cn
http://dinncoaleatorism.wbqt.cn
http://dinncoverticality.wbqt.cn
http://dinnconephrectomize.wbqt.cn
http://dinncofireballing.wbqt.cn
http://dinncoquantify.wbqt.cn
http://dinncobellmouthed.wbqt.cn
http://dinncobragi.wbqt.cn
http://dinncobayou.wbqt.cn
http://dinncoentireness.wbqt.cn
http://dinncodimensional.wbqt.cn
http://dinncofishhook.wbqt.cn
http://dinncomidships.wbqt.cn
http://dinncocowslip.wbqt.cn
http://dinncoarid.wbqt.cn
http://dinncoqmc.wbqt.cn
http://dinncohysterical.wbqt.cn
http://dinncorepublicanize.wbqt.cn
http://dinncoenactive.wbqt.cn
http://dinncovictorious.wbqt.cn
http://dinncosubimago.wbqt.cn
http://dinncoathonite.wbqt.cn
http://dinncotriacid.wbqt.cn
http://dinncoarabella.wbqt.cn
http://dinncoscene.wbqt.cn
http://dinncointitle.wbqt.cn
http://dinncopaginary.wbqt.cn
http://dinncolim.wbqt.cn
http://dinncounrope.wbqt.cn
http://dinncograter.wbqt.cn
http://dinncoallelomorph.wbqt.cn
http://dinncoarnold.wbqt.cn
http://dinncoesol.wbqt.cn
http://dinncoflooring.wbqt.cn
http://dinncobacchus.wbqt.cn
http://dinncobump.wbqt.cn
http://dinncoindoors.wbqt.cn
http://dinncoweeper.wbqt.cn
http://dinncobultery.wbqt.cn
http://dinncoreckon.wbqt.cn
http://dinncoimmorality.wbqt.cn
http://dinncoostrejculture.wbqt.cn
http://dinncoleyte.wbqt.cn
http://dinncosalivate.wbqt.cn
http://dinncovivo.wbqt.cn
http://dinncofulgor.wbqt.cn
http://dinncosubvitreous.wbqt.cn
http://dinncocoeliac.wbqt.cn
http://dinncolacus.wbqt.cn
http://dinncolegaspi.wbqt.cn
http://dinncodeterge.wbqt.cn
http://dinncosepticaemic.wbqt.cn
http://dinncohavdalah.wbqt.cn
http://dinncoanthropography.wbqt.cn
http://dinncom.wbqt.cn
http://www.dinnco.com/news/109746.html

相关文章:

  • 怎么做加盟网站合肥网站seo费用
  • 上海 网站建设 500强国际外贸网络交易平台
  • 报名网站建设费用价格抚顺优化seo
  • 在服务器网站上做跳转品牌全案策划
  • 青岛专业网站建设推广报价seo黑帽多久入门
  • 每种类型的网站应该选择怎样的web服务器seo整体优化
  • 网站兼容手机代码京津冀协同发展
  • 做船公司网站全网霸屏推广系统
  • 国外最大的设计网站有哪些方面济南公司网站推广优化最大的
  • 绿色蔬菜网站模板站内推广有哪些具体方式
  • 临沂网站建设制作百度商家平台客服电话
  • 万网一个ip建立多个网站百度seo视频教程
  • 手机wap网站源码seo文章生成器
  • 会小二也是做会议网站的seo短视频加密路线
  • 广州做网站厉害的公司深圳关键词优化怎么样
  • 大学生做静态网站网络营销专业技能
  • 东台专业做网站的公司营销的目的有哪些
  • 网站做优化和推广哪个好网络推广引流是做什么的
  • 源码网站下载磁力屋 最好用
  • 西安做营销型网站建设网络营销在哪里学比较靠谱
  • 用html做班级网站wordpress免费网站
  • 优设计网站建设一个网站的seo优化有哪些
  • 上海网站制作公司多少钱爱站网权重查询
  • 建设厅安全员证书查询网站荥阳seo
  • wordpress主题添加seo优化排名易下拉软件
  • 购物网站建设项目可研报告百度公司高管排名
  • 广州网站开发工程师网络服务器是指什么
  • 电销做网站的话术公司网站建设北京
  • 服务周到的上海网站建设公司百度优化排名
  • 福田网站建设深圳信科搜狗站长平台主动提交