F - Ants CodeForces - 318D

제목
조훈의 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]); } } }

좋은 웹페이지 즐겨찾기