일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 또 2시네
- 또 2시야....
- 멋쟁이사자처럼후기
- 2시야
- 파이썬
- 5기
- BOJ
- 난 분명히 1시에 잘 생각이었는데
- 알고리즘
- 백준
- 몰라 뭐가 너무 많아졌어
- astreisk
- jupyter_notebook
- 멋사
- 정렬
- activation_function
- 23883
- 데이터분석
- 멋쟁이사자처럼부트캠프
- TDB
- 자동_형변환
- ELU
- O(logN)
- 선택정렬
- 멋쟁이사자처러후기
- root_directory
- comprehesion
- 다 쓰고 보니깐 1시 반이야
- Python
- 다 쓰고보니깐
Archives
- Today
- Total
유사개발자 샤이와 무지
곱하기 혹은 더하기 [Greedy] #이것이 코딩테스트다 본문
[문제] 곱하기 혹은 더하기: 문제 설명
각 자리가 숫자(0부터 9)로만 이루어진 문자열 S가 주어졌을 때,왼쪽부터 오른쪽으로 하나씩 모든 숫자를 확인하며숫자 사이에 'X' 혹은 '+' 연산자를 넣어 결과적으로 만들어질 수 있는 가장 큰 수를 구하는 프로그램을 작성하세요.단, +보다 X를 먼저 계산하는 일반적인 방식과는 달리, 모든 연산은 왼쪽에서부터 순서대로 이루어진다고 가정합니다.
예를 들어 02984라는 문자열이 주어지면, 만들어질 수 있는 가장 큰 수는 (((( 0 + 2 ) x 9) x 8) x 4) = 576 입니다.또한, 만들어질 수 있는 가장 큰 수는 항상 20억 이하의 정수가 되도록 입력이 주어집니다..
난이도: ●○○| 풀이시간 30m | 시간제한 1초 | 메모리 128mb
<input case>
첫째 줄에 여러 개의 숫자로 구성된 하나의 문자열 S가 주어집니다. (1 <= S의 길이 <= 20)
<Output case>
첫째 줄에 만들어질 수 있는 가장 큰 수를 출력합니다.
input example | Output example |
02984 | 576 |
567 | 210 |
<Idea>
Q. 간단한 문제, 맨 뒷자리가 0이 아니더라도 문제 없게 설계 + list처럼 데이터를 하나하나 불러오기 위해 input을 문자열로 유지하였음
n=input()
res=1
for i in n:
if i != "0": res*=int(i) #i가 0인 케이스 이외에선 곱하는게 가장 커지는 길
#else: res+=0 #들어온 숫자가 0이면 0을 더해줘도 되지만 최적화를 위해 제거
print(res)
'WIL > algorithm' 카테고리의 다른 글
만들 수 없는 금액 [Greedy] #이것이 코딩테스트다 (1) | 2023.05.19 |
---|---|
문자열 뒤집기 [Greedy] #이것이 코딩테스트다 (0) | 2023.05.19 |
모험가 길드 [Greedy] #이것이 코딩테스트다 (0) | 2023.05.19 |
커리큘럼 [theory of graph] #이것이 코딩테스트다 (2) | 2023.05.16 |
도시 분할 계획 [theory of graph] #이것이 코딩테스트다 #백준 1647 (0) | 2023.05.16 |
Comments