![5555번: 반지](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2Fc7NpOc%2FbtsEP9WXpd3%2FAJe0ZBtb6do8Q2pNwf2zh1%2Fimg.png)
![스몰스테핑](https://t1.daumcdn.net/tistory_admin/static/manage/images/r3/default_L.png)
5555번: 반지백준/문제2024. 2. 13. 13:19
Table of Contents
문제 출처 : https://www.acmicpc.net/problem/5555
5555번: 반지
당신은 N개의 반지를 가지고 있다. 각각의 반지는 대문자 10 문자로 이루어진 문자열이 새겨져 있다. 반지는 문자열의 시작과 끝이 연결된 형태로 문자가 새겨져 있다. 반지에 각인된 문자열을
www.acmicpc.net
언어 : Kotlin
문제 설명 :
당신은 N개의 반지를 가지고 있다. 각각의 반지는 대문자 10 문자로 이루어진 문자열이 새겨져 있다. 반지는 문자열의 시작과 끝이 연결된 형태로 문자가 새겨져 있다. 반지에 각인된 문자열을 거꾸로 읽는 걱정은 없다.
찾고자하는 문자열이 주어졌을 때 그 문자열을 포함하는 반지가 몇 개인지를 발견하는 프로그램을 작성하라.
입력 :
입력은 총 2 + N 줄 이다.
첫 번째 줄에는 1 자 이상 10 자 이하의 대문자로 구성된 찾고자 하는 문자열이 적혀있다.
두 번째 줄에는 반지의 개수 N (1 ≦ N ≦ 100)이 적혀있다.
2+i 줄(1 ≦ i ≦ N)엔 i개의 반지에 새겨져있고, 10 문자로 이루어진 문자열이 적혀있다.
출력 :
찾고자하는 문자열을 포함 반지의 개수를 나타내는 정수를 한 줄로 출력하라.
제한 사항 :
- 시간 제한 : 1초
- 메모리 제한 : 128MB
입출력 예 :
입력 | 출력 |
ABCD 3 ABCDXXXXXX YYYYABCDXX DCBAZZZZZZ |
2 |
XYZ 1 ZAAAAAAAXY |
1 |
PQR 3 PQRAAAAPQR BBPQRBBBBB CCCCCCCCCC |
2 |
풀이 :
import java.io.BufferedWriter
import java.io.OutputStreamWriter
import java.util.*
fun main() = with(System.`in`.bufferedReader()) {
val bw = BufferedWriter(OutputStreamWriter(System.out))
val str = readLine()
val n = readLine().toInt()
var result = 0
repeat(n) {
val queue: Queue<Char> = LinkedList()
readLine().forEach { queue.add(it) }
for (i in queue.indices) {
if (queue.joinToString("").regionMatches(0, str, 0, str.length)) {
result++
break
} else {
queue.add(queue.poll())
}
}
}
bw.write("$result")
bw.flush()
bw.close()
}
'백준 > 문제' 카테고리의 다른 글
3029번: 경고 (0) | 2024.02.14 |
---|---|
3028번: 창영마을 (0) | 2024.02.14 |
11586번: 지영 공주님의 마법 거울 (0) | 2024.02.08 |
2804번: 크로스워드 만들기 (1) | 2024.02.08 |
2002번: 추월 (1) | 2024.02.07 |
![스몰스테핑](https://t1.daumcdn.net/tistory_admin/static/manage/images/r3/default_L.png)
@스몰스테핑 :: 작은 발걸음
포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!