【五月集训5.1】——数组

请添加图片描述

☘前言☘

开更五月集训专题,由浅入深,深入浅出,飞向大厂!

🧑🏻作者简介:一个从工业设计改行学嵌入式的年轻人
✨联系方式:2201891280(QQ)
全文大约阅读时间: 20min



2016. 增量元素之间的最大差值

2016. 增量元素之间的最大差值

解题思路

利用前缀最小值进行遍历一遍就ok了。

代码

class Solution {
public:
    int maximumDifference(vector<int>& nums) {
        int ans = -1, n = nums.size(),qianzuimin = nums[0];
        for(int i = 1;i < n;++i){
            if(nums[i] - qianzuimin > 0)    ans = max(ans,nums[i] - qianzuimin);//统计结果
            qianzuimin = min(qianzuimin,nums[i]);//更新前缀最小值
        }
        return ans;
    }
};

注意的点

  1. 先将nums的size进行保存,防止每次就都调用浪费时间
  2. 每次都直接赋值,省了分支语句加快速度
  3. 其实前缀最小值先计算还是后计算不影响结果,因为要求是绝对的大于,如果是大于等于就会有影响。

2239. 找到最接近 0 的数字

2239. 找到最接近 0 的数字

解题思路

简单模拟,不过说了要用c++,用用auto遍历的方式。

代码

class Solution {
public:
    int findClosestNumber(vector<int>& nums) {
        int ans = 100001;
        for(auto num : nums){
            int tmp = num > 0 ? num : -num;
            if(tmp < abs(ans))  ans = num;
            else if(tmp == abs(ans) && num > ans) ans = num;
        }
        return ans;
    }
};

注意的点

  1. 使用:的形式进行遍历,比较省事。
  2. 要求返回的是值,要看清题呀。

1475. 商品折扣后的最终价格

1475. 商品折扣后的最终价格

解题思路

典型单调栈问题,为了省空间,省时间,输入数组直接改0.0

代码

class Solution {
public:
    vector<int> finalPrices(vector<int>& prices) {
        stack<int> zhan;
        int n = prices.size();
        for(int i = 0;i < n;++i){
            while(!zhan.empty() && prices[zhan.top()] >= prices[i] ){
                int tmp = zhan.top();
                prices[tmp] -= prices[i];
                zhan.pop();
            }
            zhan.push(i);
        }
        return prices;
    }
};

注意的点

  1. C++的pop返回值是void,这有点离谱,不返回出栈元素。。。
  2. 使用n来避免重复取内存, tmp同理。

2248. 多个数组求交集

2248. 多个数组求交集

解题思路

因为都不相同,直接统计出现次数,然后如果出现次数等于数组行数就是结果。

代码

class Solution {
public:
    vector<int> intersection(vector<vector<int>>& nums) {
        vector<int> ans;
        map<int, int> map;
        for(auto numcol : nums)
            for(auto num : numcol)  ++map[num];

        for(auto iter : map)
            if(iter.second == nums.size())
                ans.push_back(iter.first);
        return ans;
    }
};

注意的点

  1. C++的挺好的点就是懒得写类型就auto。。。

写在最后

今天成功练习了vectormap,c++的stl学习进度++。0.0

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

XingleiGao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值