문제 출처 : https://www.acmicpc.net/problem/5698
언어 : Kotlin
문제 설명 :
선영이는 시를 매우 좋아한다. 최근에 선영이는 시집을 읽다가 매우 매력적인 시형을 찾았다. Tautogram은 매우 특별한 형태의 두운법으로, 인접한 단어가 같은 글자로 시작하는 것을 말한다.
문장이 Tautogram이 되려면, 모든 단어가 같은 글자로 시작해야 한다.
아래 문장은 모두 Tautogram이다.
Flowers Flourish from France
Sam Simmonds speaks softly
Peter pIckEd pePPers
truly tautograms triumph
선영이는 Tautogram을 이용해서 남자친구에게 줄 연애 편지를 쓰려고 한다. 선영이의 편지에 있는 문장이 주어졌을 때, Tautogram인지 아닌지 알아내는 프로그램을 작성하시오.
입력 :
각 테스트 케이스는 한 줄로 이루어져 있고, 선영이 편지의 한 문장에 해당한다.
문장은 최대 50개의 단어로 이루어져 있으며, 공백으로 구분되어져 있다. 단어는 알파벳 대문자와 소문자로 이루어져 있고, 길이는 최대 20이다.
단어는 적어도 한 글자를 포함하며, 문장은 적어도 한 단어를 포함한다.
마지막 테스트 케이스의 다음 줄에는 *이 하나 주어진다.
출력 :
각 테스트 케이스에 대해서, 입력으로 주어진 문장이 Tautogram이라면 'Y'를, 아니라면 'N'을 출력한다.
제한 사항 :
- 시간 제한 : 1초
- 메모리 제한 : 128MB
입출력 예 :
입력 | 출력 |
Flowers Flourish from France Sam Simmonds speaks softly Peter pIckEd pePPers truly tautograms triumph this is NOT a tautogram * |
Y Y Y Y N |
풀이 :
import java.io.BufferedReader
import java.io.BufferedWriter
import java.io.InputStreamReader
import java.io.OutputStreamWriter
fun main() = with(BufferedReader(InputStreamReader(System.`in`))) {
val bw = BufferedWriter(OutputStreamWriter(System.out))
var input: String?
while (true) {
input = readLine()
if (input == "*") break
val count = input.split(" ").map { it[0].lowercaseChar() }.groupingBy { it }.eachCount().size
bw.appendLine(if (count == 1) "Y" else "N")
}
bw.flush()
bw.close()
}
'백준 > 문제' 카테고리의 다른 글
17218번: 비밀번호 만들기 (0) | 2024.06.21 |
---|---|
1334번: 다음 팰린드롬 수 (0) | 2024.06.21 |
20112번: 사토르 마방진 (0) | 2024.06.20 |
글로벌 포닉스 (0) | 2024.06.20 |
末尾の文字 (Last Letter) (0) | 2024.06.20 |
포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!