题目链接
这道题思路很简单,就是在输入每一个人的坐标时,每一个坐标都判断一下在不在高风险范围内,但注意题目对“逗留“的定义为连续在风险区停留了n时刻。所以在输入的坐标不在风险区时,要把前面累计的在风险区的时刻数清零重新计算。前面所计的时刻数存储到另一个临时变量里,每一次清零都要将之前的累计数字与新要存入的数字比大小,只存入最大的即可。
注意:如果一直处于高风险区,那么temp2 将一直为零,所以鉴于我们之后使用temp2作为判断依据,所以temp2要再与temp1比一次大小。
#include <stdio.h>
int main()
{
int n,k,t,x1,y1,x2,y2;
scanf("%d %d %d %d %d %d %d",&n,&k,&t,&x1,&y1,&x2,&y2);
int i,j;
int x,y;
int temp1=0,temp2=0;
int pass=0,stay=0;
for(i=0;i<n;i++){
for(j=0;j<t;j++){
scanf("%d %d",&x,&y);
if((x>=x1&&x<=x2)&&(y>=y1&&y<=y2))
temp1++; //记录在高风险区的时刻数
else{
if(temp1>temp2)//比较要存入的数字与之前存入的时刻数大小
temp2=temp1;
temp1=0;//清零}
}
if(temp1>temp2)
temp2=temp1;//假使一直在风险区需给temp2赋值
if(temp2>=k) {
stay++;}
else if(temp2>0){
pass++;
}
temp1=0;
temp2=0;
}
printf("%d\n%d",pass+stay,stay);
}