일단 맨 처음과 끝에 공백이 있을 수 있어서 strip()으로 사전에 양쪽 공백을 제거한 후, 문제에서 제시한 기준인 '단어는 띄어쓰기 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다'에 의거해서 strip()으로 양쪽 공백을 처리한 문자열 내의 띄어쓰기를 count한 후 거기다 +1을 해주는 원리입니다.
+1을 해주는 이유는 예를 들어 My name is John 과 같은 문장에서 양쪽 공백이 없는 한, "단어의 개수 = 문자열 내의 띄어쓰기 개수 + 1" 을 해주기 때문입니다.
예제는 물론이고 다른 문장도 대입해봐서 이상이 없는데, 시간초과도 아니고 왜 틀리는지 궁금합니다
input().split()으로 해서 하는 방법도 있긴 한데 왜 이 방법이 안되는지 궁금합니다
asdf1357 3년 전
일단 맨 처음과 끝에 공백이 있을 수 있어서 strip()으로 사전에 양쪽 공백을 제거한 후, 문제에서 제시한 기준인 '단어는 띄어쓰기 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다'에 의거해서 strip()으로 양쪽 공백을 처리한 문자열 내의 띄어쓰기를 count한 후 거기다 +1을 해주는 원리입니다.
+1을 해주는 이유는 예를 들어 My name is John 과 같은 문장에서 양쪽 공백이 없는 한, "단어의 개수 = 문자열 내의 띄어쓰기 개수 + 1" 을 해주기 때문입니다.
예제는 물론이고 다른 문장도 대입해봐서 이상이 없는데, 시간초과도 아니고 왜 틀리는지 궁금합니다
input().split()으로 해서 하는 방법도 있긴 한데 왜 이 방법이 안되는지 궁금합니다