Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- VirtualTryON
- 네이버 부스트캠프 ai tech 6기
- score distillation
- video generation
- dreammotion
- magdiff
- Programmers
- 코딩테스트
- controllable video generation
- visiontransformer
- DP
- segmentation map
- diffusion models
- diffusion
- segmenation map generation
- 프로그래머스
- diffusion model
- 3d editing
- BOJ
- Vit
- image editing
- video editing
- style align
- controlnext
- 코테
- 논문리뷰
- Python
- 3d generation
- transformer
- emerdiff
Archives
- Today
- Total
평범한 필기장
[Programmers_Python] 가장 큰 수 본문
https://school.programmers.co.kr/learn/courses/30/lessons/42746#
내 풀이방식
처음에 단순히 입력 값들을 string 형태로 바꾸고 그대로 정렬을 실시했다. 하지만 2번째 테스트 케이스를 보면 3, 30 ,34가
34, 3, 30으로 정렬이 되야하지만 사전형식으로 정렬을 하게 되면 34, 30, 3으로 정렬이 된다. 그래서 나는 좀 복잡하게 생각해서 풀었다.
def solution(numbers):
numbers = list(map(str, numbers))
numbers.sort(reverse = True)
# print(numbers)
for i in range(len(numbers)-1):
if numbers[i][0] == numbers[i+1][0]:
n = max(len(numbers[i]),len(numbers[i+1]))
num1 = numbers[i]*n
num2 = numbers[i+1]*n
# print(num1,num2)
# print(num1[:n], num2[:n])
if num1[:n] < num2[:n]:
num1 = numbers[i]
num2 = numbers[i+1]
numbers[i] = num2
numbers[i+1] = num1
# print(numbers)
return ''.join(numbers)
정답 풀이
다른 사람들은 34, 3, 30을 어떻게 정렬을 했는지를 확인해봤는데, 조건이 1000이하의 정수이므로 입력값들의 길이를 3배로 늘려주고 그 늘려준 입력값들을 사전식으로 정렬하는 방식으로 간단히 푼 것을 확인했다. 그리고 입력이 [0,0,0,0]일 경우 0이 나와야하는 경우도 내가 생각을 못했다. 이 경우를 위해 join을 시킨 것을 정수로 바꾸고 그것을 다시 문자열로 변환해 준 것을 볼 수 있다.
def solution(numbers):
numbers_str = [str(num) for num in numbers]
numbers_str.sort(key=lambda num: num*3, reverse=True)
return str(int(''.join(numbers_str)))
'코딩 테스트 준비 > Programmers' 카테고리의 다른 글
[Programmers_Python] 큰 수 만들기 (0) | 2023.05.08 |
---|---|
[Programmers_Python] 다리를 지나는 트럭 (0) | 2023.05.02 |
[Programmers_Python] 뒤에 있는 큰 수 찾기 (0) | 2023.04.04 |
[Programmers_Python] 2개 이하로 다른 비트 (0) | 2023.04.04 |
[Programmers_Python] 위장 (0) | 2023.03.31 |