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

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

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

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7
코딩 테스트/삼성 기출

2017상_테트리스 블럭 안의 합 최대화 하기

코딩 테스트/삼성 기출

2017상_테트리스 블럭 안의 합 최대화 하기

2024. 6. 8. 17:02

https://www.codetree.ai/training-field/frequent-problems/problems/max-sum-of-tetris-block/description?page=3&pageSize=20

 

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

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

www.codetree.ai

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

a=[list(map(int,input().split())) for _ in range(n)]
ans=0

#  우,하,좌,상
dx=[0,1,0,-1]
dy=[1,0,-1,0]

visit=[[0]*m for _ in range(n)]

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

def dfs(x,y,cnt,s):
    global ans,visit

    if cnt==4:
        ans=max(ans,s)
        return
    if not inBoard(x,y):
        return
    if visit[x][y]==1:
        return
    visit[x][y]=1
    for k in range(4):
        nx,ny=x+dx[k],y+dy[k]
        dfs(nx,ny,cnt+1,s+a[x][y])
    visit[x][y]=0

def simulate(x,y,s):
    global ans

    if inBoard(x-1,y) and inBoard(x+1,y):
        ns=s+a[x-1][y]+a[x+1][y]
        if inBoard(x,y+1):
            ans=max(ans,ns+a[x][y+1])
        if inBoard(x,y-1):
            ans=max(ans,ns+a[x][y-1])

    if inBoard(x,y-1) and inBoard(x,y+1):
        ns=s+a[x][y-1]+a[x][y+1]
        if inBoard(x+1,y):
            ans=max(ans,ns+a[x+1][y])
        if inBoard(x-1,y):
            ans=max(ans,ns+a[x-1][y])

for x in range(n):
    for y in range(m):
        dfs(x,y,0,0)
        simulate(x,y,a[x][y])

print(ans)

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

2017하_조삼모사  (0) 2024.06.09
2017상_외주 수익 최대화하기  (0) 2024.06.08
2017상_방화벽 설치하기  (0) 2024.06.08
2017상_자율주행 자동차  (0) 2024.06.08
2024상_마법의 숲 탐색  (0) 2024.06.08
    '코딩 테스트/삼성 기출' 카테고리의 다른 글
    • 2017하_조삼모사
    • 2017상_외주 수익 최대화하기
    • 2017상_방화벽 설치하기
    • 2017상_자율주행 자동차
    Carnival7
    Carnival7

    티스토리툴바

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.