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

电台网站建设要求建一个电影网站多大 数据库

电台网站建设要求,建一个电影网站多大 数据库,济南网站建设求职简历,网络营销都有哪些形式本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章…

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章中,我不仅会讲解多种解题思路及其优化,还会用多种编程语言实现题解,涉及到通用解法时更将归纳总结出相应的算法模板。

为了方便在PC上运行调试、分享代码文件,我还建立了相关的仓库。在这一仓库中,你不仅可以看到LeetCode原题链接、题解代码、题解文章链接、同类题目归纳、通用解法总结等,还可以看到原题出现频率和相关企业等重要信息。如果有其他优选题解,还可以一同分享给他人。

由于本系列文章的内容随时可能发生更新变动,欢迎关注和收藏征服LeetCode系列文章目录一文以作备忘。

给你一个非空数组,返回此数组中 第三大的数 。如果不存在,则返回数组中最大的数。

示例 1:

输入:[3, 2, 1]
输出:1
解释:第三大的数是 1

示例 2:

输入:[1, 2]
输出:2
解释:第三大的数不存在, 所以返回最大的数 2

示例 3:

输入:[2, 2, 3, 1]
输出:1
解释:注意,要求返回第三大的数,是指在所有不同数字中排第三大的数。
此例中存在两个值为 2 的数,它们都排第二。在所有不同数字中排第三大的数为 1

提示:

  • 1 <= nums.length <= 10^4
  • -2^31 <= nums[i] <= 2^31 - 1

进阶: 你能设计一个时间复杂度 O(n) 的解决方案吗?


解法 遍历

思路:先去重复,再排序的做法/用堆的方法都是 n log ⁡ n n\log n nlogn 级别的,因此不考虑。下面是我第一次做的方法。先循环找出第一大(最大)的数,再找出第二大的数,再循环找出第三大的数, O ( 3 n ) O(3n) O(3n) 的复杂度。

class Solution {
public:int thirdMax(vector<int>& nums) {long firMax = LONG_MIN, secMax = LONG_MIN, thiMax = LONG_MIN;for (int i = 0; i < nums.size(); ++i) if (nums[i] > firMax) firMax = nums[i]; for (int i = 0; i < nums.size(); ++i) if (nums[i] > secMax && nums[i] < firMax) secMax = nums[i];for (int i = 0; i < nums.size(); ++i) if (nums[i] > thiMax && nums[i] < secMax) thiMax = nums[i]; if (thiMax == LONG_MIN) return firMax;return thiMax;}
};

然后其实,可以合成一个循环。像是冒泡或者是单调队列,用 a , b , c a, b,c a,b,c 分别表示最大值,次大值和第三大的数。

  • 如果当前元素比 a a a 大,则说明其一定比 b b b c c c 都大。 我们同时更新 b b b c c c 的值。 具体来说就是将 b b b 更新到 c c c a a a 更新到 b b b (可以形象地考虑成是把元素往后挤出去)。
  • 否则我们继续判断是否比 b b b 大,如果比 b b b 大,那么肯定也比 c c c 大,我们同时需要更新 c c c 的值。
  • 如果都不比 a a a b b b 大,我们继续判断是否比 c c c 大,如果是,我们更新c的值。

我们初始化 a , b , c a,b,c a,b,c 为 负无穷(LONG_MIN)。 这样我们最后只要判断 c c c 是不是负无穷即可,如果是负无穷我们返回 a a a ,否则我们返回 c c c

class Solution {
public:int thirdMax(vector<int>& nums) { long a = LONG_MIN, b = LONG_MIN, c = LONG_MIN; for (int &num : nums) {if (num > a) {c = b; b = a; a = num;} else if (num > b && num < a) {c = b; b = num;} else if (num > c && num < b) {c = num;}}return (c == LONG_MIN) ? a : c;}
};

另一种不依赖元素范围的做法是,将 a a a b b b c c c 初始化为空指针或空对象,视作「无穷小」,并在比较大小前先判断是否为空指针或空对象。遍历结束后,若 c c c 为空,则说明第三大的数不存在,返回 a a a ,否则返回 c c c

class Solution {
public:int thirdMax(vector<int> &nums) {int *a = nullptr, *b = nullptr, *c = nullptr;for (int &num : nums) {if (a == nullptr || num > *a) {c = b;b = a;a = &num;} else if (*a > num && (b == nullptr || num > *b)) {c = b;b = &num;} else if (b != nullptr && *b > num && (c == nullptr || num > *c)) {c = &num;}}return c == nullptr ? *a : *c;}
};

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n) ,其中 n n n 是数组 nums \textit{nums} nums 的长度。
  • 空间复杂度: O ( 1 ) O(1) O(1)
http://www.yayakq.cn/news/771025/

相关文章:

  • p2p贷款网站开发网站没有被收录原因
  • 建筑材料东莞网站建设建设银行深圳培训中心网站
  • 自做网站视频环球易购招聘网站建设
  • 公司网站运营方案域名访问wordpress小图标不显示
  • 做一个论坛网站多少钱58同城怎么发布广告信息
  • 做网站的windowlcd易优cms破解
  • 响应式网站建设新闻小程序开发平台哪个产品好
  • 闲置tp路由自己做网站wordpress前端登录插件
  • 国外优秀网站建设营销网站开发规划
  • 网站建设教程书籍广东工程建设监理协会网站
  • 哪家公司做网站建设比较好代理财务记账公司
  • 为网站添加isapi扩展短视频推广代理
  • 做网站的岗位叫什么机械网站建设多少钱
  • 做外包网站wordpress企业网站开发
  • 网站设计与管理论文长春网站推广优化
  • 廉江网站制作山西省住房城乡建设厅网站首页
  • 杨凌网站建设推广运用vs2010c 做网站
  • 重庆网站建设 吧网站开发测量像素工具
  • 这么制作自己的网站西安专业得网站建设公司
  • 房产中介网站建设的目的网站自己做余额充值自动扣款
  • 龙口网站设计做销售找客户的网站
  • 木蚂蚁网站正在建设中聚美优品网站建设项目规划书
  • 合肥外贸网站建设iis建立网站
  • 沈阳建设网站公司广州建设集团股份有限公司
  • 成都APP,微网站开发wordpress中文博客
  • 门户网站建设工作讲话怎么找网站帮我做推广
  • 怎么做网站才能吸引人电脑做ppt模板下载网站
  • 网站制作成功案例上海搬家公司电话附近
  • 网站后台的用户名重庆铜梁网站建设费用
  • 北京门户网站制作公司长沙房产网最新楼盘地图