Notice
Recent Posts
Recent Comments
12-12 21:18
«   2024/12   »
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
Archives
Today
Total
관리 메뉴

-

[백준] #1373 2진수 8진수 - 파이썬 본문

Algorithm

[백준] #1373 2진수 8진수 - 파이썬

choiht 2022. 7. 14. 16:14
반응형

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

 

1373번: 2진수 8진수

첫째 줄에 2진수가 주어진다. 주어지는 수의 길이는 1,000,000을 넘지 않는다.

www.acmicpc.net

 

내 코드

a = int(input())  #숫자를 입력받음
b = str(a)    #입력받은 숫자를 문자열로 바꿈
sum = 0      #변환된 10진수를 저장할 변수    
mul = 0      

for i in range(len(b)-1,-1,-1):
    sum += (int(b[i]) * (2**mul))
    mul += 1


#8진수는 0o314 같이 앞에 "0o"이 붙으므로 
#"o"를 기준으로 분리해서 뒤의 숫자만 출력
print(oct(sum).split("o")[1])

하지만 제출해보니 시간초과로 통과되지 못했다.

구글링을 해본 결과 코드는 한줄로 정리될 수 있었다.

print(oct(int(input(),2))[2:])

int()에 ,를 쓰고 뒤에 숫자를 넣으면 그 진법의 숫자를 받는다.

여기서는 int(input(),2)라서 2진법의 숫자를 받는다.

그리고 oct()로 값을 변환했기 때문에 8진법 숫자로 바뀌고, 8진수는 0o314 같이 앞에 "0o"이 붙으므로 이를 제거하기 위해 [2:]를 이용한다.

 

반응형

'Algorithm' 카테고리의 다른 글

[백준 10814] 나이순 정렬  (0) 2023.04.18
[백준 7568] 덩치  (1) 2023.04.17
[백준 1181] 단어 정렬  (2) 2023.04.15
[백준 1541] 잃어버린 괄호  (0) 2023.01.25
[파이썬] enumerate  (0) 2021.01.26
Comments