luogu. P2105

#include<bits/stdc++.h>//万能头文件

using namespace std;

int x[600],y[600];

int a,b,c;

int flag[20010],q[20010],m,n;

int main()

{

 cin>>a>>b>>c;

 for(int i=1;i<=c;i++) 

  cin>>x[i]>>y[i],q[x[i]]=1;

 for(int i=1;i<=a;i++)

 {

  if(q[i]) 

   continue;

  m=b;

  for(int j=1;j<=c;j++)

  {

   if(flag[y[j]]!=i) m-=1;

   flag[y[j]]=i;

   if(x[j]<i)

   {

    if(y[j]+i-x[j]>=1&amp;&amp;y[j]+i-x[j]<=b) 

    {

     if(flag[y[j]+i-x[j]]!=i) m-=1;

     flag[y[j]+i-x[j]]=i;

    }

    if(y[j]-i+x[j]>=1&amp;&amp;y[j]-i+x[j]<=b) 

    {

     if(flag[y[j]-i+x[j]]!=i) m-=1;

     flag[y[j]-i+x[j]]=i;

    }

   }

   else 

   {

    if(y[j]+(x[j]-i)>=1&amp;&amp;y[j]+(x[j]-i)<=b)

    {

     if(flag[y[j]+(x[j]-i)]!=i) m-=1;

     flag[y[j]+(x[j]-i)]=i;

    }

    if(y[j]-(x[j]-i)>=1&amp;&amp;y[j]-(x[j]-i)<=b)

    {

     if(flag[y[j]-(x[j]-i)]!=i) m-=1;

     flag[y[j]-(x[j]-i)]=i;

    }

   }

  }

  n+=m;

 }

 cout<<n;//输出

 return 0;

 }

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值