👩‍💻 알고리즘/🐢 PYTHON

백준 2902번

오브 🧙‍♂️ 2024. 7. 10. 03:35

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

 

문제 >

다장조는 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인지 판별하는 프로그램을 작성하시오.

 

솔루션 :

list로 입력받고 비교하면 될 것 같다.

num = list(map(int,input().split(" ")))

if num == [1,2,3,4,5,6,7,8]:
    print('ascending')
elif num == [8,7,6,5,4,3,2,1]:
    print('descending')
else:
    print('mixed')

 

map 함수는 map(function, iterable1, iterable2, ...) 형태로 여러개의 객체를 리스트 형태로 받는다.

이 문제는 정수값으로, 입력받은 문자열을 띄어쓰기로 구분해서 리스트로 정리되어야하므로 코드는 다음과 같다.

 

밑에 기능은 if로 정리해주면 되겠다.

 

sorted를 쓰는 방법도 있다.

a = list(map(int, input().split()))

if a == sorted(a):
    print('ascending')
elif a == sorted(a,reverse=True):
    print('descending')
else:
    print('mixed')

sorted는 기본적으로 오름차순으로 정리해서 새로운 리스트를 만든다.

reverse=True를 덧붙이면 내림차순으로 정리된다.

'👩‍💻 알고리즘 > 🐢 PYTHON' 카테고리의 다른 글

[스택 예제] 백준 10828번  (0) 2024.07.09
[스택 예제] 백준 9012번  (0) 2024.07.07
[스택 예제] 백준 10773번  (0) 2024.07.07
배열을 numpy로 변환  (0) 2023.09.19
arange 함수  (0) 2023.09.19