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

江苏赛华建设监理有限公司网站全网推广推荐

江苏赛华建设监理有限公司网站,全网推广推荐,做教育app的网站有哪些,做问卷的网站有哪些题目描述 https://leetcode.cn/problems/longest-consecutive-sequence/description/?envTypestudy-plan-v2&envIdtop-100-liked 给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。 请你…

题目描述

https://leetcode.cn/problems/longest-consecutive-sequence/description/?envType=study-plan-v2&envId=top-100-liked

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:

输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。
示例 2:

输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

我的答案

class Solution {
public:int longestConsecutive(vector<int>& nums) {if (0==nums.size()){return 0;}std::sort(nums.begin(),nums.end());// for (auto it=nums.begin();it!=nums.end();it++)// {//     std::cout<<*it<<std::endl;// }int max_result=1;int max_result_temp=1;for(int i=nums.size()-1;i>0;--i){// std::cout<<"i="<<i<<std::endl;// std::cout<<"nums[i]="<<nums[i]<<std::endl;// std::cout<<"nums[i-1]="<<nums[i-1]<<std::endl;if(1==(nums[i]-nums[i-1])){max_result_temp++;//std::cout<<"max_result_temp="<<max_result_temp<<std::endl;if (max_result_temp>max_result){max_result=max_result_temp;}}else if(0==(nums[i]-nums[i-1])){max_result_temp;//std::cout<<"max_result_temp="<<max_result_temp<<std::endl;if (max_result_temp>max_result){max_result=max_result_temp;}}else{// is_consecutive=false;max_result_temp=1;}}return max_result;}
};
#include <iostream>
#include <vector>
#include <algorithm>
#include <iostream>
#include <unordered_map>
#include <string>class Solution
{
public:int longestConsecutive(std::vector<int> &nums){if (0 == nums.size()){return 0;}std::sort(nums.begin(), nums.end());// for (auto it=nums.begin();it!=nums.end();it++)// {//     std::cout<<*it<<std::endl;// }int max_result = 1;int max_result_temp = 1;for (int i = nums.size() - 1; i > 0; --i){// std::cout<<"i="<<i<<std::endl;// std::cout<<"nums[i]="<<nums[i]<<std::endl;// std::cout<<"nums[i-1]="<<nums[i-1]<<std::endl;if (1 == (nums[i] - nums[i - 1])){max_result_temp++;// std::cout<<"max_result_temp="<<max_result_temp<<std::endl;if (max_result_temp > max_result){max_result = max_result_temp;}}else if (0 == (nums[i] - nums[i - 1])){max_result_temp;// std::cout<<"max_result_temp="<<max_result_temp<<std::endl;if (max_result_temp > max_result){max_result = max_result_temp;}}else{// is_consecutive=false;max_result_temp = 1;}}return max_result;}
};int main()
{std::vector<int> nums = {100, 4, 200, 1, 3, 2};int result;Solution test1;result = test1.longestConsecutive(nums);std::cout << "result=" << result << std::endl;std::cout << "     " << std::endl;return 0;
}

编译:

g++ 128_最长连续序列.cpp -o main

输出

4

解题思路

先排序,然后倒着循环作差,值为1,则累加,不然重新开始累加,记住要记住最大值,且需要考虑多种边界情况,比如一个数据,没有数据,重复数据等。特别是重复数据。

注意: 后面我会学习排序后去重的C++库函数

知识点

sort库函数使用

这里需要包含头文件

#include <algorithm>

不然找不到头文件
在 C++ 中,你可以使用 头文件中的库函数来进行排序。以下是一些常用的排序函数:

std::sort():对容器或指定范围内的元素进行排序,默认按升序排序。注意:std::sort(),不光能对数字进行排序,还可以对字母进行排序。

#include <algorithm>
#include <vector>int main() {std::vector<int> nums = {5, 2, 8, 1, 9};std::sort(nums.begin(), nums.end());// 输出排序后的结果for (const auto& num : nums) {std::cout << num << " ";}return 0;
}

输出结果:1 2 5 8 9

注意输入为0判断,边界条件判断

输入数组长度为0:

 if (0 == nums.size()){return 0;}

其他优化解题

使用哈希表

http://www.dinnco.com/news/50452.html

相关文章:

  • 集团公司网站开发seo要点
  • 网站设计与规划作业网站维护需要学什么
  • 合肥微网站制作苏州百度 seo
  • 石家庄求职信息网茂名seo顾问服务
  • 专业建设网站百度一下你就知道下载
  • 怎么做qq刷会员的网站国内免费域名注册
  • 用商城系统做教育网站站长工具网
  • 杭州滨江区建设局网站seo工作流程
  • 龙华做手机网站建设大连seo网站推广
  • 网站域名出售郑州网站推广排名公司
  • 网站背景音乐怎么做企业培训的目的和意义
  • 建设通官方网站大数据精准营销获客
  • 唐山百度做网站多少钱百度识图搜索网页版
  • 培训机构的网站建设东莞网站建设做网站
  • 网站开发行业工作交接交接哪些微网站
  • 学院网站建设规划网店seo关键词
  • 网页传奇辅助seo信息是什么
  • o2o网站建设方案讲解seo外链是什么意思
  • 长沙网站推广智投未来seo网络优化专员
  • apache php mysql wordpressseo自学教程seo免费教程
  • 简述网站开发具体流程武汉网站优化公司
  • 网站开发工程师特点今日新闻头条热点
  • 华强北做电子网站app推广活动策划方案
  • 门户网站建设与开发sem电子扫描显微镜
  • 建设厅网站用户名和密码百度网首页
  • 前端做网站使用的软件工具制作网站的工具
  • 西安做网站找哪家公司好武汉十大技能培训机构
  • 企业建站wordpress网页设计自学要多久
  • 山东德州网站建设哪家便宜nba季后赛最新排名
  • 建一网站要多少钱qq群引流推广平台