虽说周末要早起来着,但是日子过得有点奇怪,一不小心就忘掉了。。。

leetcode414 https://leetcode.com/problems/third-maximum-number/?tab=Description

leetcode485 https://leetcode.com/problems/max-consecutive-ones/?tab=Description

leetcode495 https://leetcode.com/problems/teemo-attacking/?tab=Description

======================================

414说的是
给你n个数字(无序,有重复),输出第三大的数,如果没有,输出最大的,使用O(n)的算法。注意,你的排序中不能有相同的,也就是说如果输入2,3,2,3,我们要输出3,因为没有第三大的数字。

我的思路
这题目,一下子就会想到堆priority_queue,但是堆是nlogn的,好吧,手动维护三个数字分别表示最大、次大、次次大好了,但是初始化设成什么值好呢,用0x80 memset一下好了,得到的是-1e9,感觉 够大了。

 class Solution {
public:
int thirdMax(vector<int>& nums) {
int aim[];
int n=nums.size();
memset(aim,0x80,sizeof(aim));
for(int i=;i<n;i++){
if(nums[i]>aim[]){
aim[]=aim[];
aim[]=aim[];
aim[]=nums[i];
}
if(aim[]>nums[i]&&nums[i]>aim[]){
aim[]=aim[];
aim[]=nums[i];
}
if(aim[]>nums[i]&&nums[i]>aim[]){
aim[]=nums[i];
}
}
return aim[]==aim[]?aim[]:aim[];
}
};

WA

结果提交了一次,返回了WA,人家有数据是-2e9的。。。。好吧,那就写标记,用给的元素维护赋初值好了。

 class Solution {
public:
void swap(int &x,int &y){
x^=y;y^=x;x^=y;
}
int thirdMax(vector<int>& nums) {
int aim[],flag=;
int n=nums.size();
memset(aim,0x80,sizeof(aim));
for(int i=;i<n;i++){
if(flag==){
aim[]=nums[i];
flag++;
continue;
}
if(flag==){
if(nums[i]==aim[])continue;
aim[]=nums[i];
if(aim[]<aim[])swap(aim[],aim[]);
flag++;
continue;
}
if(flag==){
if(nums[i]==aim[]||nums[i]==aim[])continue;
if(nums[i]>aim[]){
aim[]=aim[];
aim[]=aim[];
aim[]=nums[i];
}else if(aim[]>nums[i]&&nums[i]>aim[]){
aim[]=aim[];
aim[]=nums[i];
}else aim[]=nums[i];
flag++;
continue;
}
if(nums[i]>aim[]){
aim[]=aim[];
aim[]=aim[];
aim[]=nums[i];
}
if(aim[]>nums[i]&&nums[i]>aim[]){
aim[]=aim[];
aim[]=nums[i];
}
if(aim[]>nums[i]&&nums[i]>aim[]){
aim[]=nums[i];
}
}
return flag!=?aim[]:aim[];
}
};

AC

完成是完成了,这也太丑了吧。。。去学习学习别人的写法。结果发现了这个。。。。

 int thirdMax(vector<int>& nums) {
set<int> top3;
for (int num : nums)
if (top3.insert(num).second && top3.size() > )
top3.erase(top3.begin());
return top3.size() == ? *top3.begin() : *top3.rbegin();
}

(很优美。。。。不想折叠),虽然set确实提供了logn的复杂度用来插入和删除,但是我们只需要前3大的数据,所以set的size只需要有3就好,log3算是常数.。。。。。。。心悦诚服

=======================================

485说的是
给你一个数组,只由01组成,问你最长的连续的1有多长
我的思路
没有思路,暴力出奇迹,扫一遍就好。

 class Solution {
public:
int findMaxConsecutiveOnes(vector<int>& nums) {
int n=nums.size(),temp=,aim=;
for(int i=;i<n;i++){
if(nums[i])temp++;
else{
aim=max(aim,temp);
temp=;
}
}
aim=max(aim,temp);
return aim;
}
};

485

========================================

495说的是
有一个人的攻击可以让敌人中毒,毒会持续duration个时间单位,他会攻击很多次(不超过1e4),告诉你每次攻击的时间(非负,不超过1e7),问你敌人一共中毒中多久。
比如输入[1,2] 2 输出3
表示1秒2秒各攻击一次,每次中毒持续2秒,敌人一共中毒3秒

我的思路:
因为数据没有保证有序,先排序一下,然后扫一遍,记录每一个中毒区间的头尾,在出区间的时候统一计算时间加到答案里。复杂度O(nlogn)

 class Solution {
public:
int findPoisonedDuration(vector<int>& timeSeries, int duration) {
vector<int> nums(timeSeries);
int n=nums.size();
sort(nums.begin(),nums.end(),less<int>());
int aim=,st=-,et=-;
for(int i=;i<n;i++){
if(nums[i]>et){
aim+=et-st;
st=nums[i];
et=st+duration;
}else{
et=nums[i]+duration;
}
}
aim+=et-st;
return aim;
}
};

495

很不开心啊。。。发现居然(75ms)只击败了27.6%不开心啊,看了看讨论版,发现别人的代码好像没有排序,我去题面看了看,人家加粗了一个单词“ascending ”,我当时不明白,以为是攻击力会提升,,,,现在明白了,人家说的是升序给出攻击时间序列2333333
好吧,去掉sort后63ms,击败了67%。。。。就这样吧,毕竟评测机不稳定。。。

2017-3-4 leetcode 414 485 495的更多相关文章

  1. C#版 - Leetcode 414. Third Maximum Number题解

    版权声明: 本文为博主Bravo Yeung(知乎UserName同名)的原创文章,欲转载请先私信获博主允许,转载时请附上网址 http://blog.csdn.net/lzuacm. C#版 - L ...

  2. 2017/11/22 Leetcode 日记

    2017/11/22 Leetcode 日记 136. Single Number Given an array of integers, every element appears twice ex ...

  3. 2017/11/21 Leetcode 日记

    2017/11/21 Leetcode 日记 496. Next Greater Element I You are given two arrays (without duplicates) num ...

  4. 2017/11/13 Leetcode 日记

    2017/11/13 Leetcode 日记 463. Island Perimeter You are given a map in form of a two-dimensional intege ...

  5. 2017/11/20 Leetcode 日记

    2017/11/14 Leetcode 日记 442. Find All Duplicates in an Array Given an array of integers, 1 ≤ a[i] ≤ n ...

  6. 2017/11/9 Leetcode 日记

    2017/11/9 Leetcode 日记 566. Reshape the Matrix In MATLAB, there is a very useful function called 'res ...

  7. 2017/11/7 Leetcode 日记

    2017/11/7 Leetcode 日记 669. Trim a Binary Search Tree Given a binary search tree and the lowest and h ...

  8. 2017/11/6 Leetcode 日记

    2017/11/6 Leetcode 日记 344. Reverse String Write a function that takes a string as input and returns ...

  9. 2017/11/5 Leetcode 日记

    2017/11/5 Leetcode 日记 476. Number Complement Given a positive integer, output its complement number. ...

随机推荐

  1. Selenium等待某个元素出现之隐式等待

    找不到元素这个问题困扰了两天了,一直怀疑是页面div层次太多,定位不准确.于是就从table开始到最后一层精确定位,仍然找不元素.怎么办,在网上搜索答案,说是可以加个隐式试试,于是在执行前加了一句等待 ...

  2. 最影响APP软件质量和成本的三个方面。希望大家一定要记在心里!

    1.功能的开发方式 现在市场上存在的几种开发方式如下: a.web网页加壳生成APP web网页加壳生成APP的开发方式,先花几百块钱买个现成的手机网站模板,在加壳打包一个APP只需要5分钟,但是做出 ...

  3. 关于安卓调用wcf的一些问题

    最近公司有个项目需要和别的系统做对接,对方开放的是webservice接口,搞了很久终于搞出来了,在此记录一下 获取数据的service public class SoapService implem ...

  4. C++中内存分配、函数调用和返回值问题

    转载博客:http://blog.csdn.net/q_l_s/article/details/52176159(源地址找不到,就贴了这位大神的博客地址,他也是转载的,不过要是学习的话,他的博客很不错 ...

  5. Teamwork-六月上旬心得体会

    六月上旬心得体会 在五月末的时候,老师针对我们团队的状况提出了几点建议和解决方案,而这半个月里,我们尝试性地运用了其中的几件工具与方法. 1.燃尽图与每日总结 我们采用的是<构建之法>书中 ...

  6. 用户 'NT Service\MSSQLServerOLAPService' 登录失败

    初学SSAS,部署微软官方示例项目AdventureWorksDW2012Multidimensional时出现错误:用户 'NT Service\MSSQLServerOLAPService' 登录 ...

  7. 基于ACE的TAO开发---一个简单的入门实例-----VS2008(二)

    上一节已经说了如何编译idl文件.现在就用编好的文件来写一个最小的corba小程序的.程序分为服务器程序和客户端程序. 说明下,代码是<基于C++CORBA高级编程>一书中的例子. 1.首 ...

  8. 记我安装Caffe的血泪史(1)

    Caffe的安装我主要参考的是这篇博客 http://blog.csdn.net/ubunfans/article/details/47724341 按照他的方法我很快就安好了cuda8(为后面安装了 ...

  9. WIN系统查询版本

    cmd -> DISM /online /Get-CurrentEdition //查询系统版本 WIN+R -> slmgr.vbs -ipk 查询系统注册信息slmgr.vbs -dl ...

  10. 何使用ultraiso软碟通制作u盘启动盘(转载)

        现在很多网友都不知道如何用UltraISO软件来制作制作u盘启动盘,那么今天U大师小编就来给大家简单的介绍两种方法,首先第一种方法就是网友要到网上下载一个UltraISO软件,这个网上有很多的 ...