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

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

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

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7

Change Developer

코딩 테스트/삼성 기출

구현/시뮬레이션) 17822.원판 돌리기

2022. 4. 5. 20:02

https://www.acmicpc.net/problem/17822

 

17822번: 원판 돌리기

반지름이 1, 2, ..., N인 원판이 크기가 작아지는 순으로 바닥에 놓여있고, 원판의 중심은 모두 같다. 원판의 반지름이 i이면, 그 원판을 i번째 원판이라고 한다. 각각의 원판에는 M개의 정수가 적혀

www.acmicpc.net

#second.
# 탐색 알고리즘 :
# 각 칸의 오른쪽과 아래쪽과 비교하여 같은 지 확인한다.
# check 배열로 같으면 True 로 하여, 탐색 중 원본 a를 안전하게 지킨다.
from collections import deque

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

a=[None]

dx=[-1,0,1,0]
dy=[0,-1,0,1]

for i in range(n):
    d=deque(list(map(int,input().split())))
    a.append(d)

# 원판 회전
def rotation(x,d,k):
    global a

    # 번호가 xi의 배수인 원판을 di방향으로 ki칸 회전시킨다. di가 0인 경우는 시계 방향, 1인 경우는 반시계 방향이다.
    for i in range(1,n+1):
        if i%x==0:
            if d==0: # 시계 방향
                a[i].rotate(k)
            else: # 반시계방향
                a[i].rotate(-k)

# 인접한 수 중 같은 수 찾기
# 각 칸의 오른쪽과 아래쪽과 비교하여 같은 지 확인한다.
# check 배열로 같으면 True 로 하여, 탐색 중 원본 a를 안전하게 지킨다.
def find_adjacent_same():
    global a

    adjacent_same = False

    check=[[False]*m for _ in range(n+1)]

    for i in range(1,n+1):
        for j in range(m):
            if a[i][j]==0:
                continue
            if a[i][j]==a[i][(j+1)%m]:
                check[i][j] = check[i][(j+1)%m] = True
            if i+1<=n and a[i][j] == a[i+1][j]:
                check[i][j] = check[i+1][j] = True

    for i in range(1,n+1):
        for j in range(m):
            if check[i][j]:
                adjacent_same=True
                a[i][j]=0

    return adjacent_same

# 원판 위의 수의 평균 구하기
def get_avg():
    global a

    total_sum,cnt=0,0

    for i in range(1,n+1):
        for j in range(m):
            if a[i][j]!=0:
                total_sum+=a[i][j]
                cnt+=1

    if cnt == 0:
        return

    return total_sum/cnt

# 시뮬레이션
for _ in range(t):
    x,d,k = map(int,input().split())

    #1
    rotation(x, d, k)

    #2. 인접하면서 수가 같은 것을 모두 찾는다.
    # 그러한 수가 있는 경우에는 원판에서 인접하면서 같은 수를 모두 지운다.
    adjacent_same = find_adjacent_same()
    # 없는 경우에는 원판에 적힌 수의 평균을 구하고, 평균보다 큰 수에서 1을 빼고, 작은 수에는 1을 더한다.
    if not adjacent_same:
         avg=get_avg()
         for i in range(1,n+1):
             for j in range(m):
                 if a[i][j]!=0:
                     if a[i][j]>avg:
                         a[i][j]-=1
                     elif a[i][j]<avg:
                         a[i][j]+=1

answer=sum(sum(row) for row in a[1:])

print(answer)

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

2022하_코드트리 빵  (0) 2023.03.29
2022하_싸움땅(2024/04/06 업데이트)  (0) 2023.03.29
브루트포스) 17070.파이프 옮기기 1  (0) 2022.10.03
시뮬레이션과 구현) 20057.마법사 상어와 토네이도  (0) 2022.10.01
구현) 3190. 뱀  (0) 2021.09.15
    '코딩 테스트/삼성 기출' 카테고리의 다른 글
    • 2022하_싸움땅(2024/04/06 업데이트)
    • 브루트포스) 17070.파이프 옮기기 1
    • 시뮬레이션과 구현) 20057.마법사 상어와 토네이도
    • 구현) 3190. 뱀
    Carnival7
    Carnival7

    티스토리툴바