[백준] 1384번: 메시지

응갱·2022년 9월 26일
0

백준

목록 보기
23/56
post-thumbnail

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

📎문제

Misfits 아카데미는 문제아들을 위한 치유 시간을 도입했습니다. 그 중 한 가지 활동은 아이들이 타인에 대해 예의를 갖출 수 있도록 고안되었으며, 내용은 아래와 같습니다.

아이들은 원형으로 앉은 뒤 종이 위에 자신의 이름을 적습니다. 다음 각자의 종이를 자기 왼편으로 전달합니다. 종이를 전달받았으면, 종이 맨 위에 쓰인 이름을 가진 아이에 대해 좋은 메시지를 써줍니다. "너는 멋져.", "도와줘서 고마워"같은 말들을요. 메시지는 종이 아래쪽에 적으며, 적은 뒤에는 종이를 접어 가립니다. 다음으로 종이를 왼편으로 넘기고 같은 활동을 반복합니다. 자신의 이름이 맨 위에 적힌 종이를 받으면 활동을 종료하고 각자 다른 아이들이 자기에게 남긴 메시지들을 읽어봅니다.

하지만 가끔 "넌 너무 말이 많아.", "니 옷 후져."처럼 제멋대로 글을 쓰는 아이들이 있습니다. 이런 글을 읽게 되면 기분이 좋지 않겠죠? 이런 말을 한 아이를 알려주세요!

📎입력

입력은 번호를 가진 그룹들로 이루어져 있습니다. 그룹의 번호는 1부터 시작하며 1씩 증가합니다. 각 그룹의 입력은 참여한 아이들의 수 n(5 ≤ n ≤ 20)이 한 줄에 주어지면서 시작됩니다. 다음 n 줄에 걸쳐 위 활동을 끝마친 종이 n장이 입력됩니다. n 줄의 순서는 아이들이 앉아있고 종이를 넘기던 순서와 같습니다. 예를 들어 첫 번째 줄에 해당하는 아이는 두 번째 줄에 해당하는 아이에게 종이를 넘겼고, 마지막 줄에 해당하는 아이는 첫 번째 줄에 해당하는 아이에게 종이를 넘겼습니다.

각 줄은 종이 맨 위의 이름으로 시작합니다. 다음으로 공백을 사이에 두고 종이에 적힌 메시지가 종이 위에서부터 아래로 순서대로 쓰입니다. 문제를 간단하게 하기 위해 좋은 메시지는 'P'로, 나쁜 메시지는 'N'으로 표기합니다. 이름은 60글자 이하의 알파벳 소문자 또는 대문자로 이루어져 있습니다.

마지막 줄에 '0'이 입력되면서 입력이 종료됩니다. '0'은 처리하지 않습니다.

📎출력

그룹 번호를 "Group 1"과 같이 출력함으로써 출력을 시작합니다. 그 다음 줄부터 누가(A) 누구(B)에게 나쁜 말을 했는지 "A was nasty about B"로 한 줄씩 출력합니다. 나쁜 말이 여러 개라면, 입력받은 순서대로─첫 번째 종이부터, 왼쪽에서 오른쪽으로─출력합니다. 아무도 나쁜 말을 하지 않았다면 "Nobody was nasty"를 출력합니다.

각 그룹을 빈 줄로 구분합니다.

📎코드

import java.util.Scanner;

public class pr1384 {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int num = 0;
		while (true) {
			int n = sc.nextInt();
			if (n == 0)
				break;

			sc.nextLine();

			String[] Arr = new String[n];
			for (int i = 0; i < n; i++) {
				Arr[i] = sc.nextLine();
			}

			String[][] sp = new String[n][n];

			for (int i = 0; i < n; i++) {
				sp[i] = Arr[i].split(" ");
			}
			num++;
			System.out.println("Group " + num);

			int cnt = 0; // cnt값이 0이면 Nobody was nasty 출력

			for (int i = 0; i < n; i++) {
				for (int j = 1; j < n; j++) {
					if (sp[i][j].equals("N"))
						cnt++;
				}
			}
			if (cnt == 0)
				System.out.println("Nobody was nasty");
			else {
				for (int i = 0; i < n; i++) {
					for (int j = 1; j < n; j++) {
						if (sp[i][j].equals("N")) {
							if (i >= j)
								System.out.println(sp[i - j][0] + " was nasty about " + sp[i][0]);
							if (i < j)
								System.out.println(sp[n - (j - i)][0] + " was nasty about " + sp[i][0]);
						}
					}
				}
			}
			System.out.println();
		}

	}

}

📎코드해석

  • 각 입력을 nextLine을 이용해 Arr 배열에 한번에 받는다.

  • String형 2차원 배열 spString클래스의 split 메소드를 활용해 Space 키를 기준으로 나누었다.

  • 배열 sp의 1열은 모두 이름을 나타낸다.

    예시

    AnnPNPP
    BobPPPP
    ClivePPPP
    DebbyPNPP
    EunicePPPP
  • for문을 이용해 'N'의 개수 cnt를 셌다. cnt값이 0이면 "Nobody was nasty"가 출력된다.

  • 'N'의 위치 인덱스 값에 따라 "A was nasty about B" 가 출력되도록 했다.

🥔후기

생각보다 쉽게 풀었다고 생각하는데 nextLine 사용 전에 버퍼를 처리하는 걸 깜빡해서 이상한데서 헤맸다;;... 항상 헷갈린다 😭

profile
🥔 한 덩이

0개의 댓글

관련 채용 정보