[Python] 백준 11576 - Base Conversion, 반례,오답 피드백

2021. 2. 2. 01:43·Coding Test(Algorithms)
반응형

안녕하세요

진짜.. 이거하나가지고 삽질을 너무해서 억울해서 포스팅합니다. 다시는 이런 실수하지 않으리..

여러분도 한번 생각해보세요. 이 코드가 왜 틀렸을까? ... 함께해요..

전 바보라서 1시간넘게 붙들고 있었습니다.........


이 문제는 a진법 수를 b진법으로 변환 출력하는 문제입니다.

즉, a진법을 10진법으로 바꾼 뒤 b진법으로 변환해야 합니다.

단순하죠?

 

자꾸 틀렸다고 뜨시는 분들은 제가 찾은 반례를 시도해보세요.

 

반례는

>> 8 17

>> 2

>> 6 2

 

올바른 출력은

2 16

 

입니다.


~ 코드 해석 ~

 

첫 번째 for문에서 10진법으로 바꾼 수를 num_10에 저장합니다.

그리고 while문을 돌며 b진법으로 바꾸기 위해 answer에 결과를 하나씩 추가해줍니다.

import sys
a,b=map(int, sys.stdin.readline().rstrip().split())
m=int(sys.stdin.readline().rstrip())
k=sys.stdin.readline().rstrip().split()
num_10=0

for i in range(m):
    num=int(k[i])
    num_10+= (num* (a**(m-i-1)) )

answer=[]    
# answer=""

while num_10:
    r=num_10%b
    num_10=num_10//b
    answer.append(str(r))
    #answer+=str(r)

sys.stdout.write(' '.join(answer[::-1]))

중간에 주석 처리한 answer = "" 와

while문 내부의 answer += str(r) 로 하면 틀린 답이 나옵니다.

주석 바로 윗줄이 맞는 코드입니다.

 

 

 

왜 그럴까요?

 

 

 

이유는 list형과 string형의 차이에 있습니다.

 

예를 들면,

8진법의 62를 17진법으로 바꾸려고 한다면,

62(8) -> 50(10) -> 216(17)

이런 순서를 거쳐야합니다. (괄호안의 수는 진법을 나타냅니다.)

 

이 때 최종 정답인 216(17)을 담기 위한 answer을 str로 설정해놓으면,

50(10)을 17로 나눈 나머지인 16, 2가 차례대로 저장될 때

answer = "162" 으로 저장됩니다.

 

이제 이걸 거꾸로 출력하기 위해 마지막 줄에서 answer[::-1]을 사용하는데, 그럼 당연히

2 6 1 

이 출력되고, 16이 1과 6으로 해체되버리는 것입니다.

 

이걸 왜 놓쳤지? 정말 어이가 없군요

list형으로 담으면 answer=[ "16", "2" ] 으로 저장되므로, 거꾸로 돌려도 16이 1과 6으로 해체되지 않죠(당연히)

 

 

 

소통하고 싶은 내용이 있으면 언제든 댓글주세요.

모두들 똑똑한 하루 되시길 바랍니다.

 

 

 

 

 

반응형
저작자표시 (새창열림)

'Coding Test(Algorithms)' 카테고리의 다른 글

[JAVA] 입출력 예제 - 백준 10950  (0) 2021.06.15
[JAVA] 입출력 예제 - 백준 1000  (0) 2021.06.15
[Python] 백준 문자열(Strings), Linked-Lists 문제 풀이 팁(tip) 정리  (0) 2021.01.29
[Python] 백준 Stack/Queue/Deck 문제 풀이 팁(tip) 정리  (0) 2021.01.28
[Python] 백준 정렬 (sorting) 기본 문제, 답, 풀이 팁(tip) 정리  (0) 2021.01.27
'Coding Test(Algorithms)' 카테고리의 다른 글
  • [JAVA] 입출력 예제 - 백준 10950
  • [JAVA] 입출력 예제 - 백준 1000
  • [Python] 백준 문자열(Strings), Linked-Lists 문제 풀이 팁(tip) 정리
  • [Python] 백준 Stack/Queue/Deck 문제 풀이 팁(tip) 정리
RED BEAN
RED BEAN
웹 프론트엔드 개발블로그입니다. 대화하고싶으시다면 댓글 혹은 ghdqlsdl9633@gmail.com 이메일주시면 감사히 답변하겠습니다. [GitHub - https://github.com/Hong-been]
반응형
RED BEAN
REDBEAN
RED BEAN
전체
오늘
어제
  • 분류 전체보기 (102)
    • 계속하는개발 (6)
    • Development (45)
    • Coding Test(Algorithms) (47)
    • Info. (1)

블로그 메뉴

  • 홈
  • 태그
  • 방명록
  • 관리자

공지사항

인기 글

태그

  • 스파르타코딩클럽
  • 자바입출력
  • 자바스크립트
  • JS
  • 코딩테스트
  • 이직
  • Flask
  • 글또
  • 웹개발
  • 플라스크웹개발
  • 티스토리챌린지
  • 노마드코더
  • 온라인강의
  • 모던자바스크립트딥다이브
  • html
  • 국비학원
  • pymongo
  • 오블완
  • node
  • 프론트엔드
  • 개발자
  • 자바
  • 코테
  • React
  • 백준
  • MongoDB
  • css
  • 코딩강의
  • nestjs
  • 회고

최근 댓글

최근 글

hELLO· Designed By정상우.v4.5.2
RED BEAN
[Python] 백준 11576 - Base Conversion, 반례,오답 피드백

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.