深信服笔试9.1a卷

#include <bits/stdc++.h>
using namespace std;
//判断是否有交集
bool help0(vector<long long>& vec1, vector<long long>& vec2){
    if(vec1[0] < vec2[0] && vec1[1] < vec2[0]){
        return false;
    }
    if(vec1[0] > vec2[1] && vec1[1] > vec2[1]){
        return false;
    }
    return true;
}

int main(){
    // freopen("123123.txt", "r", stdin);
    long long n = 0, x = 0;
    cin >> n >> x;
    vector<vector<long long>> vec;
    vec.reserve(n);
    for(int i = 0; i < n; ++i){
        long temp = 0;
        cin >> temp;
        vec.push_back(vector<long long>{temp-x, temp+x});
    }
    
    vector<long long> help;
    long long ans = 0;
    for(auto& v : vec){
        if(help.empty()){
            help = v;
            continue;
        }
        if(help0(v, help)){
            help[0] = ::max(help[0], v[0]);
            help[1] = ::min(help[1], v[1]);
        }else{
            help = v;
            ++ans;
        }
    }
    cout << ans << endl;
    
    return 0;
}
第三题“病毒”通过0%,我不理解,求大佬帮忙看一下#深信服笔试题#
全部评论
我也是自己怎么测都没有问题但就是0,楼主找到原因了吗
点赞 回复 分享
发布于 2022-09-14 21:07 四川
代码思路就是取交集,没有试验过,不知道对不对,仅供参考
点赞 回复 分享
发布于 2022-09-02 00:37 广西
和leetcode合并区间很像
点赞 回复 分享
发布于 2022-09-01 23:30 广东
病毒那个求交集就行了,如果到一个数交集不了,病毒就要变换一次,然后区间从这次开始。
点赞 回复 分享
发布于 2022-09-01 22:01 广东
把题目想复杂了吧,是按顺序入侵主机的,一个个确定上下限就行了
点赞 回复 分享
发布于 2022-09-01 21:35 浙江

相关推荐

评论
3
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务