F - Ants CodeForces - 318D
16753 단어 acm 더위 훈련codeforces
조훈의 cf문제는 당시에 줄곧 쓰지 못했지만 어떻게 쓰는지 모르면 짜증이 난다. 마이너스일 수 있기 때문에 우리는 (0,0)를 (100001000)과 결합하여 제목이 정한 개미의 수량으로 바꾸면 더 이상 마이너스가 나올 수 없다. 먼저 bfs가 모든 개미의 위치를 미리 처리하면 매우 편하지만 세부 사항이 제대로 되지 않아 요약했다.
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define ll long long
#define ms(a,b) memset(a,b,sizeof(a))
#define lowbit(x) x & -x
#define fi first
#define ull unsigned long long
#define se second
#define endl "
"
#define bug cout<
#define IOS ios::sync_with_stdio(false), cin.tie(0),cout.tie(0)
using namespace std;
const int maxn =1e5 + 5;
const int maxm = 1.5e5+50;
const double eps = 1e-7;
const double inf = 0x3f3f3f3f;
const double lnf = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9+7;
const double pi=3.141592653589;
struct node
{
int x;
int y;
};
int dp[2005][2005];
int dir[4][2]= {{-1,0},{1,0},{0,-1},{0,1}};
void bfs(int s)
{
queue<node>q;
q.push({1000,1000});
dp[1000][1000]=s;// s
while(!q.empty())
{
node temp=q.front();
q.pop();
if(dp[temp.x][temp.y]<4)
{
continue ;
}
int T=dp[temp.x][temp.y]/4;
dp[temp.x][temp.y]=dp[temp.x][temp.y]%4;
for(int i=0; i<4; i++)
{
int x=temp.x+dir[i][0];
int y=temp.y+dir[i][1];
int z=T;
q.push({x,y});
dp[x][y]+=T;// 。
}
}
}
int main()
{
int n,t;
scanf("%d%d",&n,&t);
bfs(n);
for(int i=1; i<=t; i++)
{
int x,y;
scanf("%d %d",&x,&y);
if(x<=-1000||y<=-1000||x>=1000||y>=1000)
{
printf("0
");
}
else
{
printf("%d
",dp[1000+x][1000+y]);
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Codeforces Round #510 (Div. 2) D. Petya and Array 좌압과 세그먼트 트리문제는 바꿔 말하면, 구간 $[l, r)$의 부분합이 $t$ 미만의 부분합이 되는, $l,r$의 수를 요구하고 싶다. 즉, $a_0$에서 있는 $a_i$까지의 합을 index로, 출현 횟수를 값으로 하는 세그먼트 트...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.