CCF小白刷题之路---202009-2 风险人群筛查(C/C++ 100分)

简介: CCF小白刷题之路---202009-2 风险人群筛查(C/C++ 100分)

1.题目描述
image.png
image.png
image.png
image.png
2.解题思路
本题难点在于逗留的判断,逗留的意思是要该居民连续去过k次及以上的高危地区才算做逗留,所以我在这里定义了一个结构体,其中max_dl用来记录每次循环时该居民的最大连续逗留次数,最后与k进行大小比较判断该居民是否属于逗留。

3.代码实现

#include<iostream>
using namespace std;

struct person{
    int jg; //经过高危地区的次数
    int dl; //连续经过高危地区的次数
    int max_dl; //最大连续经过高危地区的次数
};

int main()
{
    int n,k,t,x1,y1,x2,y2;
    cin>>n>>k>>t>>x1>>y1>>x2>>y2;
    int sum_jg=0,sum_dl=0;
    person per[n];
    for(int i=0;i<n;i++)
    {
        per[i].jg = 0;
        per[i].dl = 0;
        per[i].max_dl = 0;
        for(int j=0;j<t;j++)
        {
            int person_x,person_y;
            cin>>person_x>>person_y;
            if(person_x>=x1 && person_x<=x2 && person_y>=y1 && person_y<=y2)
            {
                per[i].jg++;
                per[i].dl++;
                if(per[i].dl > per[i].max_dl) per[i].max_dl = per[i].dl;
                //找寻最大的连续经过次数,最后与k进行判断
            }
            else per[i].dl = 0;
        }
        if(per[i].jg>0) sum_jg++;
        if(per[i].max_dl>=k) sum_dl++;
    }
    cout<<sum_jg<<endl<<sum_dl<<endl;
    return 0;
}
相关文章
|
机器学习/深度学习 算法 安全
CCF—CSP第一题题解(C++)
CCF—CSP第一题题解(C++)
240 0
CCF—CSP第一题题解(C++)
|
C++
【牛客刷题】带你在牛客刷题第六弹(C/C++基础)
哈喽,今天是我们牛客刷题训练第五弹,今天我们来刷一些C/C++的问题,这些问题相对于你刚学习C/C++基础来说会很好的帮助自己理解,我相信,只要我们一步步去分析,肯定是可以得到正确的答案的,来我们一起加油。
81 0
【牛客刷题】带你在牛客刷题第六弹(C/C++基础)