L1-087 机工士姆斯塔迪奥

L1-087 机工士姆斯塔迪奥

链接:题目详情 - L1-087 机工士姆斯塔迪奥 (pintia.cn)

思路:

​ 一开始就使用了数学规律做这题,就是 如果攻击了h行,那就少 h * m个格子,如果攻击了l列,那就少了 l * n个格子,同时,行列重合的格子数为 h * l 个,还要再加上它。故而,在被攻击后,安全的格子数为 n * m - h * m - l * n + h * l 个。

​ 这题被卡的地方就是可能会重复攻击某一行或列,所以要对行列加上标记,避免重复计算。

#include<iostream>
using namespace std;
bool hb[100010]={false},lb[100010]={false};
int main(){
    int h=0,l=0,n,m,q,x,y,z;
    cin>>n>>m>>q;
    for(int i=0;i<q;i++){
        cin>>x>>y;
        if(x==0){
            if(!hb[y]){
                hb[y]=true;
                h++;
            }
        }
        else{
            if(!lb[y]){
                lb[y]=true;
                l++;
            }
        }
    }
    z=n*m-h*m-l*n+h*l;
    cout<<z;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值