코틀린(Kotlin)/프로그래머스

[프로그래머스/코틀린(Kotlin)] 크기가 작은 부분 문자열

초보왕보초 2023. 11. 17. 16:17
728x90

숫자로 이루어진 문자열 t와 p에서 t에서 p와 길이가 같은 부분문자열을 추출해서,

이 부분문자열의 수가 p의 숫자보다 작거나 같은 것이 나오는 횟수를 리턴 시키기

예시)

 

풀이

  • substring() 사용하여 문자열 자르기
  • for문으로 반복하여 p의 길이만큼 t배열 속 숫자 자르기

 

제출 코드

(코드 해석해 보기)

4) i를 (t의 길이) - (p의 길이)만큼 반복한다

     t의 길이가 3141592(=7)이고 p가 271(=3)이면 t에 p의 길이만큼 있는 숫자는 5개(314, 141, 415, 159, 592)이기 때문에

     t.length - p.length보다 그 크기는 1만큼 더 크다. 그래서 0..t.length - p.length로 써준다

    그리고 t.length - p.length로 쓰면 for-loop 범위에는 iterator() 메서드가 있어야 된다고 에러 뜬다

5) substring()으로 t의(i부터, i+p길이까지) 분할한 숫자가 p보다 작거나 같을 경우에 answer++ 

 

 

 


 

 

 

범위 설정

처음엔 t.indices -p.length로 해봤었다가 인덱스범위 에러가 떠서 for문 안에 여기저기 +1을 넣어봤는데 안 되길래

그냥 0부터 t.length로 바꿔줬다

문법도 그게 맞고 인덱스범위 +1 해주는 것도 훨씬 간편하게 해 줄 수 있는 방법인 듯하다

(0..t.length 말고 0 until t.length로 쓰고 +1을 해줘도 된다)

 

 

 

for문으로 처리하기 위해서는 iterator의 다음 함수가 정의되어 있어야 동작한다고 한다

  • 지정된 자료형으로 리턴하며, 멤버 함수나 확장함수인 iterator()
  • 멤버 함수나 확장함수인 next()
  • Boolean 형으로 리턴하며, 멤버 함수나 확장 함수인 hasNext()
728x90