Carnival7
Change Developer
Carnival7
전체 방문자
오늘
어제
  • 분류 전체보기
    • 자바의 정석
    • 프로그래밍 언어별 tools
      • 파이썬
      • 자바
    • 코딩 테스트
      • 백준 강의 기초편
      • 백준 강의 연습편
      • 백준 강의 문제편
      • 삼성 기출
      • 백준 - 일반
      • 카카오 기출
      • 프로그래머스 - 일반
      • 코테 풀이 Tools
    • CS
      • Network
      • 운영체제
      • 알고리즘
      • DB
    • Web_Backend
      • Spring
      • 스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술
      • 스프링 핵심 원리 - 기본편
    • DevOps
    • IT 업무 지식
      • 인프라
      • 클라우드
    • 자격증
      • AWS - CLF
      • 정처기 - 실기
    • 생각 정리

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 슬라이딩 윈도우
  • 프로그래머스 #카카오기출 #레벨2
  • 스프링 #인터셉터 #AOP #필터
  • code deploy
  • DevOps
  • Github Actions
  • 코딩테스트 #삼성기출 #구현 #시뮬레이션
  • 삼성기출 #백준강의문제편
  • ci/cd
  • 스프링 부트 무중단 웹 서비스
  • 스프링 #AOP
  • nginx
  • 슬라이딩 윈도우 #덱
  • 알고리즘 #백준강의기초편 #코딩테스트
  • 삼성기출 #2023 #상반기
  • DMZ

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7

Change Developer

코딩 테스트/삼성 기출

2022상_나무박멸

2024. 8. 18. 16:10

https://www.codetree.ai/training-field/frequent-problems/problems/tree-kill-all?page=1&pageSize=20

 

코드트리 | 코딩테스트 준비를 위한 알고리즘 정석

국가대표가 만든 코딩 공부의 가이드북 코딩 왕초보부터 꿈의 직장 코테 합격까지, 국가대표가 엄선한 커리큘럼으로 준비해보세요.

www.codetree.ai

n,m,K,c=map(int,input().split())

a=[list(map(int,input().split())) for _ in range(n)] # 나무 맵. 빈 칸 = 0, 벽 = -1, 나무 : 1 이상
b=[[0]*n for _ in range(n)] # 제초제 맵
ans=0

#  상,하,좌,우
dx1=[-1,1,0,0]
dy1=[0,0,-1,1]

#  대각선 4방향
dx2=[-1,-1,1,1]
dy2=[-1,1,-1,1]

def inBoard(nx,ny):
    if 0<=nx<n and 0<=ny<n:
        return True
    return False

def grow():
    global a

    tmp=[[0]*n for _ in range(n)]
    dx,dy=dx1,dy1

    for x in range(n):
        for y in range(n):
            if a[x][y]>0:
                cnt=0
                for k in range(4):
                    nx,ny=x+dx[k],y+dy[k]
                    if inBoard(nx,ny) and a[nx][ny]>0:
                        cnt+=1
                tmp[x][y]+=cnt

    for x in range(n):
        for y in range(n):
            a[x][y]+=tmp[x][y]

def copyBoard(a):
    return [row[:] for row in a]

def duplicate():
    global a

    tmp=copyBoard(a)
    dx,dy=dx1,dy1

    for x in range(n):
        for y in range(n):
            if a[x][y]>0:
                cnt=0
                cand=[]
                for k in range(4):
                    nx,ny=x+dx[k],y+dy[k]
                    if inBoard(nx,ny) and a[nx][ny]==0 and b[nx][ny]<year:
                        cnt+=1
                        cand.append([nx,ny])
                for nx,ny in cand:
                    tmp[nx][ny]+=a[x][y]//cnt

    a=tmp

def select():

    dx,dy=dx2,dy2
    cand=[]

    for x in range(n):
        for y in range(n):
            if a[x][y]>0:
                cnt=a[x][y]
                for k in range(4):
                    for i in range(1,K+1):
                        nx,ny=x+dx[k]*i,y+dy[k]*i
                        if not inBoard(nx,ny):break
                        if a[nx][ny]>0:
                            cnt+=a[nx][ny]
                        else:
                            break
                cand.append([cnt,x,y])

    if len(cand)>0:
        cand.sort(key=lambda x:(-x[0],x[1],x[2]))
        return [cand[0][1],cand[0][2]]
    else:
        return None

def remove(res):
    global ans,a,b

    dx,dy=dx2,dy2
    x,y=res

    b[x][y]=c+year
    ans+=a[x][y]
    a[x][y]=0

    for k in range(4):
        for i in range(1,K+1):
            nx, ny = x + dx[k] * i, y + dy[k] * i
            if not inBoard(nx, ny): break
            b[nx][ny] = year + c
            if a[nx][ny]>0:
                ans+=a[nx][ny]
                a[nx][ny]=0
            else:
                break

year=0
for year in range(1,m+1):

    # 성장
    grow()
    # 번식
    duplicate()
    # 위치 선정
    res=select()
    # 박멸
    if res is not None:
        remove(res)

print(ans)

'코딩 테스트 > 삼성 기출' 카테고리의 다른 글

2021하_냉방 시스템(백준. 삼성 기출 - 23289.온풍기 안녕!)  (1) 2024.08.18
2021상_놀이기구 탑승(백준. 21608.상어 초등학교)  (0) 2024.08.03
2021상_색깔 폭탄(백준. 21609.상어 중학교)  (0) 2024.08.03
2018하_토스트 계란틀(백준. 16234.인구 이동)  (0) 2024.06.23
2018하_바이러스 실험(백준. 16235.나무 재테크)  (0) 2024.06.23
    '코딩 테스트/삼성 기출' 카테고리의 다른 글
    • 2021하_냉방 시스템(백준. 삼성 기출 - 23289.온풍기 안녕!)
    • 2021상_놀이기구 탑승(백준. 21608.상어 초등학교)
    • 2021상_색깔 폭탄(백준. 21609.상어 중학교)
    • 2018하_토스트 계란틀(백준. 16234.인구 이동)
    Carnival7
    Carnival7

    티스토리툴바