标签:int 题解 d% stay remain 筛查 max pass CSP
文章目录
题目链接.
算法思路
对每一个人来说,只要有一次位置落在矩阵里,就算经过高危地区,需要连续经过 k 次,才算逗留,所以把每一个人连续经过的最大次数记录下来就好。用变量 max_t
来记录最大次数,用变量remain
记录一段连续经过次数,当有一次没有经过时(断掉了),把remain
置零,更新max_t
,记住对这个人所有位置检测完之后也要再更新max_t
因为有可能他一直连续的经过高危地区,一次也没有断过。
#include<iostream>
#include<math.h>
using namespace std;
int n, k, t, xl, yd, xr, yu;
int pass = 0, stay = 0, remain = 0, max_t = 0;
//pass : 经过人数,stay : 逗留人数, remain = 1 : 保持在里边的次数, max_t 连续最多几次在里边
int x, y;
int main()
{
int i;
scanf("%d%d%d%d%d%d%d", &n, &k, &t, &xl, &yd, &xr, &yu);
while (n--)//每一个人
{
remain = 0;
max_t = 0;
for ( i = 1; i <= t; i++) //每一个时刻
{
scanf("%d%d", &x, &y);
if (x >= xl && x <= xr && y >= yd && y <= yu)//在里边
{
remain++;
}
else
{
max_t = max(max_t, remain);
remain = 0;
}
}
max_t = max(max_t, remain); //有可能一次也没有中断过,即使此时 remain = 0,也没有错
if (max_t > 0)
{
pass++;
}
if (max_t >= k)
{
stay++;
}
}
printf("%d\n%d", pass, stay);
return 0;
}
结果分析
得分100分,用时31ms,空间使用 2.941MB,时间复杂度为 O(n*t)。
标签:int,题解,d%,stay,remain,筛查,max,pass,CSP
来源: https://blog.csdn.net/weixin_44092088/article/details/110246286
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。