Notice
Recent Posts
Recent Comments
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
01-17 18:47
Archives
Today
Total
관리 메뉴

Developer_Neo

[파이썬] 2920번 : 음계 본문

프로그래밍/백준알고리즘

[파이썬] 2920번 : 음계

_Neo_ 2022. 1. 19. 15:30
반응형

 

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

 

2920번: 음계

다장조는 c d e f g a b C, 총 8개 음으로 이루어져있다. 이 문제에서 8개 음은 다음과 같이 숫자로 바꾸어 표현한다. c는 1로, d는 2로, ..., C를 8로 바꾼다. 1부터 8까지 차례대로 연주한다면 ascending, 8

www.acmicpc.net

문제

다장조는 c d e f g a b C, 총 8개 음으로 이루어져있다. 이 문제에서 8개 음은 다음과 같이 숫자로 바꾸어 표현한다. c는 1로, d는 2로, ..., C를 8로 바꾼다.

1부터 8까지 차례대로 연주한다면 ascending, 8부터 1까지 차례대로 연주한다면 descending, 둘 다 아니라면 mixed 이다.

연주한 순서가 주어졌을 때, 이것이 ascending인지, descending인지, 아니면 mixed인지 판별하는 프로그램을 작성하시오.

입력

첫째 줄에 8개 숫자가 주어진다. 이 숫자는 문제 설명에서 설명한 음이며, 1부터 8까지 숫자가 한 번씩 등장한다.

출력

첫째 줄에 ascending, descending, mixed 중 하나를 출력한다.

예제 입력 1 복사

1 2 3 4 5 6 7 8

예제 출력 1 복사

ascending

예제 입력 2 복사

8 7 6 5 4 3 2 1

예제 출력 2 복사

descending

예제 입력 3 복사

8 1 7 2 6 3 5 4

예제 출력 3 복사

mixed

 

생각

오름차순 리스트를 만들고 sorted함수를 이용해서 내림차순으로 정렬해둔 리스트 2개를 이용해서 비교하자.

 

d = list(map(int,input().split()))
a = [1, 2, 3, 4, 5, 6, 7, 8]
if a == d:
    print('ascending')
elif sorted(a, reverse=True) == d:
    print('descending')
else:
    print('mixed')

다른풀이

하나의 오름차순리스트를 만들필요없이 입력받은 것을 가지고 sorted함수를 이용하면 된다,

 

a = list(map(int, input().split()))
 
if a == sorted(a):
    print('ascending')
elif a == sorted(a, reverse=True):
    print('descending')
else:
    print('mixed')
반응형
Comments