[PGS] 최댓값과 최솟값, 음수 문자열 정렬 #99클럽10일차 #TIL
2024. 4. 9. 09:43ㆍ_Study/Baekjoon
728x90
#99클럽 #99일지 #코딩테스트 #개발자스터디 #항해 #TIL #프로그래머스
✅ 최댓값과 최솟값 설명
✅ 해결 방법
✅ 발생한 문제와 방안
✅ 최종적인 해결 방법
✅ 최적화 방안
그래서 오늘의 TIL(Today I Learned) 학습 키워드
✨ 음수 문자열 정렬
✅ 최댓값과 최솟값 설명
99클럽 미들러 난이도 최댓값과 최솟값로 ✨음수 문자열 정렬✨ 하는 방법을 알아보겠습니다.
https://school.programmers.co.kr/learn/courses/30/lessons/12939
✅ 문제설명
문자열 s에는 공백으로 구분된 숫자들이 저장되어 있습니다. str에 나타나는 숫자 중 최소값과 최대값을 찾아 이를 "(최소값) (최대값)"형태의 문자열을 반환하는 함수, solution을 완성하세요.
예를들어 s가 "1 2 3 4"라면 "1 4"를 리턴하고, "-1 -2 -3 -4"라면 "-4 -1"을 리턴하면 됩니다.
제한 조건
s에는 둘 이상의 정수가 공백으로 구분되어 있습니다.
✅ 해결 방법
공백으로 구분된 문자열을 배열로 담고 정렬한 후 ary[0]을 최솟값, ary[-1]을 최댓값으로 가져오면 될거같습니다.
✅ 발생한 문제와 방안
문자열은, -1 부터 가장 작은 순으로 처리됩니다. 이는 사전순이라서 그렇습니다. -1에서 -는 문자열 취급되기 때문에, -1보다도 -4가 더 크게 처리됩니다. 숫자로 변환하고 정렬합니다.
✅ 최종적인 해결 방법
def solution(s):
answer = ''
ary = []
for item in s.split(" "):
ary.append(int(item))
ary.sort()
answer = str(ary[0]) + " " + str(ary[-1])
return answer
✅ 최적화 방안
def solution(s):
answer = ''
ary = [int(x) for x in s.split(" ")]
ary.sort()
answer = str(ary[0]) + " " + str(ary[-1])
return answer
코드 수가 적어서 리스트 컴프리헨션만 적용했습니다.
참고자료
'_Study > Baekjoon' 카테고리의 다른 글
[PGS] 멀리뛰기 최적화, DFS 완전탐색, 동적계획법(DP) #99클럽11일차 #TIL (0) | 2024.04.10 |
---|---|
[PGS] 귤고르기 딕셔너리 최적화, Counter #99클럽9일차 #TIL (2) | 2024.04.08 |
[PGS] 프로그래머스 두 개 뽑아서 더하기, 완전탐색, 백트래킹 최적화 #99클럽8일차 #TIL (2) | 2024.04.07 |
[PGS] 프로그래머스 기사단원의 무기, 약수계산 최적화 #99클럽7일차 #TIL (0) | 2024.04.06 |
python 3.9 이하 버전을 위한 최대공약수(gcd), 최대공배수(lcm) (0) | 2024.03.20 |