https://www.acmicpc.net/problem/1152
문제
영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.
코드
str = input().split()
words = dict()
for i in str:
if i not in words:
words[i] = 0
words[i] += 1
value = words.values()
total = 0
for i in value:
total += i
print(total)
풀이
1. 문장을 리스트로 입력받고 딕셔너리 하나를 만든다.
2. 반복문으로 단어를 확인하며 딕셔너리에 없다면 추가하고 있으면 +1도 해준다
3. 이제 딕셔너리의 value값만 가져와서 total값을 구한다.
4. 구한 total값을 출력한다.
'백준 > 브론즈2' 카테고리의 다른 글
| [Python] 백준 1225번 - 이상한 곱셈 (0) | 2025.04.27 |
|---|---|
| [Python] 백준 1212번 - 8진수 2진수 (0) | 2025.04.26 |
| [Python] 백준 1673번 - 치킨 쿠폰 (0) | 2025.04.25 |
| [Python] 백준 1100번 - 하얀 칸 (0) | 2025.04.25 |
| [Python] 백준 1076번 - 저항 (0) | 2025.04.24 |