SWExpert/D3

[D3] 1206. [S/W 문제해결 기본] 1일차 - View (Python 파이썬 풀이)

MakeMoneying 2020. 9. 2. 13:26

1206. [S/W 문제해결 기본] 1일차 - View

출처

https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV134DPqAA8CFAYh&categoryId=AV134DPqAA8CFAYh&categoryType=CODE

문제

강변에 빌딩들이 옆으로 빽빽하게 밀집한 지역이 있다.

이곳에서는 빌딩들이 너무 좌우로 밀집하여, 강에 대한 조망은 모든 세대에서 좋지만 왼쪽 또는 오른쪽 창문을 열었을 때 바로 앞에 옆 건물이 보이는 경우가 허다하였다.

그래서 이 지역에서는 왼쪽과 오른쪽으로 창문을 열었을 때, 양쪽 모두 거리 2 이상의 공간이 확보될 때 조망권이 확보된다고 말한다.

빌딩들에 대한 정보가 주어질 때, 조망권이 확보된 세대의 수를 반환하는 프로그램을 작성하시오.

아래와 같이 강변에 8채의 빌딩이 있을 때, 연두색으로 색칠된 여섯 세대에서는 좌우로 2칸 이상의 공백이 존재하므로 조망권이 확보된다. 따라서 답은 6이 된다.

A와 B로 표시된 세대의 경우는 왼쪽 조망은 2칸 이상 확보가 되었지만 오른쪽 조망은 한 칸 밖에 확보가 되지 않으므로 조망권을 확보하지 못하였다.

C의 경우는 반대로 오른쪽 조망은 2칸이 확보가 되었지만 왼쪽 조망이 한 칸 밖에 확보되지 않았다.

제약 사항

가로 길이는 항상 1000이하로 주어진다.

맨 왼쪽 두 칸과 맨 오른쪽 두 칸에는 건물이 지어지지 않는다. (예시에서 빨간색 땅 부분)

각 빌딩의 높이는 최대 255이다.

입력

입력 파일의 첫 번째 줄에는 테스트케이스의 길이가 주어진다. 그 바로 다음 줄에 테스트 케이스가 주어진다.

총 10개의 테스트케이스가 주어진다.

출력

부호와 함께 테스트 케이스의 번호를 출력하고, 공백 문자 후 테스트 케이스의 조망권이 확보된 세대의 수를 출력한다.

입력
출력
 100
 0 0 225 214 82 73 241 233 179 219 135 62 36 13 6 71 179 77 67 139 31 90 9 37 ...
 1000
 0 0 225 214 82 73 241 233 179 219 135 62 36 13 6 71 179 77 67 139 31 90 9 37 ...
 ...
 #1 691

 #2 9092

 ...

문제 해석

각 빌딩 마다 꼭대기 층의 조망권을 확보한 층의 개수를 다 더해주면 된다. 순서는 가장 왼쪽 빌딩부터 보면서, 빌딩의 가장 꼭대기에서 왼쪽 오른쪽 2칸을 바라보고, 만약 조망권을 확보하면 꼭대기 다음층으로 내려가서 확인을 하는 순으로 실시하면 될 것 같다.

문제 풀이

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
def building(cnt,idx): # cnt는 왼쪽에서 몇번째 건물인지, idx는 빌딩의 층수
    global Answer
    if List[cnt-1>= idx or List[cnt-2]>=idx or List[cnt+1]>=idx or List[cnt+2]>=idx: 
        # 왼쪽으로 한칸 두칸, 오른쪽으로 한칸 두칸 봐서 idx 이상의 층수가 있으면 바로 돌아가!!
        return
    else# 만약 조망권이 확보되어 있다면
        Answer += 1 # answer값은 1 증가시키고 
        building(cnt,idx-1# 한 층 줄여서 실행
 
 
for Count in range(10):
    N = int(input())
    List = list(map(int,input().split()))
    Answer = 0
    for i in range(N):
        if List[i]: # 빌딩의 높이가 0이 아닐 때만 실행되도록 한다.
            building(i,List[i])
    print("#{} {}".format(Count+1,Answer))
cs

 

https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV134DPqAA8CFAYh&categoryId=AV134DPqAA8CFAYh&categoryType=CODE

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com