Algorithm/코딩테스트

[코딩테스트] 백준 - 인사성 밝은 곰곰이

jjuya 개발 기록 2024. 7. 22. 16:53

백준 - 인사성 밝은 곰곰이 25192번 [5일차]

시간제한 메모리 제한
1초 1024MB

문제

알고리즘 입문방 오픈 채팅방에서는 새로운 분들이 입장을 할 때마다 곰곰티콘을 사용해 인사를 한다. 이를 본 문자열 킬러 임스는 채팅방의 기록을 수집해 그 중 곰곰티콘이 사용된 횟수를 구해 보기로 했다.

ENTER는 새로운 사람이 채팅방에 입장했음을 나타낸다. 그 외는 채팅을 입력한 유저의 닉네임을 나타낸다. 닉네임은 숫자 또는 영문 대소문자로 구성되어 있다.

새로운 사람이 입장한 이후 처음 채팅을 입력하는 사람은 반드시 곰곰티콘으로 인사를 한다. 그 외의 기록은 곰곰티콘을 쓰지 않은 평범한 채팅 기록이다.

채팅 기록 중 곰곰티콘이 사용된 횟수를 구해보자!

 

입력

첫 번째 줄에는 채팅방의 기록 수를 나타내는 정수 N 이 주어진다. (1≤N≤100000)

두 번째 줄부터 N 개의 줄에 걸쳐 새로운 사람의 입장을 나타내는 ENTER, 혹은 채팅을 입력한 유저의 닉네임이 문자열로 주어진다. (1≤문자열 길이≤20)

첫 번째 주어지는 문자열은 무조건 ENTER이다.

 
 

출력

채팅 기록 중 곰곰티콘이 사용된 횟수를 출력하시오.

 

나의코드

package day5;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashSet;
import java.util.StringTokenizer;

public class Solution8 {
    // 인사성 밝은 곰곰이 25192번
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));


        int num = Integer.parseInt(br.readLine());
        int count = 0;

        HashSet<String> set = new HashSet<>();

        for(int i=0;i < num;i++){
            String line = br.readLine();
            if(line.equals("ENTER")){
                //set 비우기
                if(!set.isEmpty()){
                    set.clear();
                }
            }else { // ENTER가 아닐경우
                if(!set.contains(line)){
                    set.add(line);
                    count++;
                }
            }
        }
        System.out.println(count);

    }

}