코드트리 | 코딩테스트 준비를 위한 알고리즘 정석
국가대표가 만든 코딩 공부의 가이드북 코딩 왕초보부터 꿈의 직장 코테 합격까지, 국가대표가 엄선한 커리큘럼으로 준비해보세요.
www.codetree.ai
n,m,K=map(int,input().split())
a=[[5]*n for _ in range(n)] # 양분 맵
c=[list(map(int,input().split())) for _ in range(n)] # 양분 추가 맵
b=[[[] for _ in range(n)] for _ in range(n)] # 바이러스 맵
ans=0
# 8방향
dx=[-1,-1,-1,0,0,1,1,1]
dy=[-1,0,1,-1,1,-1,0,1]
def inBoard(nx,ny):
if 0<=nx<n and 0<=ny<n:
return True
return False
for _ in range(m):
x,y,age=map(int,input().split())
b[x-1][y-1].append(age)
for round in range(1,K+1):
p=[[0]*n for _ in range(n)]
for x in range(n):
for y in range(n):
live=[]
dead=0
b[x][y].sort()
for inx,age in enumerate(b[x][y]):
if a[x][y]>=age:
a[x][y]-=age
live.append(age+1)
if (age+1)%5==0:
for k in range(8):
nx, ny = x + dx[k], y + dy[k]
if not inBoard(nx, ny): continue
p[nx][ny]+=1
else:
dead+=age//2
a[x][y]+=dead
b[x][y]=live
a[x][y]+=c[x][y]
for x in range(n):
for y in range(n):
for _ in range(p[x][y]):
b[x][y].append(1)
for x in range(n):
for y in range(n):
if len(b[x][y])>0:
ans+=len(b[x][y])
print(ans)
'코딩 테스트 > 삼성 기출' 카테고리의 다른 글
2021상_색깔 폭탄(백준. 21609.상어 중학교) (0) | 2024.08.03 |
---|---|
2018하_토스트 계란틀(백준. 16234.인구 이동) (0) | 2024.06.23 |
2017하_돌아가는 팔각의자(백준. 14891.톱니바퀴) (0) | 2024.06.22 |
2018상_병원 거리 최소화하기(백준. 15686.치킨 배달) (0) | 2024.06.22 |
2018상_드래곤 커브(백준. 15685.드래곤 커브) (0) | 2024.06.22 |