[ Programmers ] 문자열이 몇 번 등장하는지 세기 ( java ) 82 / 124
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
📚 Table of Contents
문제 설명
문자열 myString
과 pat
이 주어집니다. myString
에서 pat
이 등장하는 횟수를 return 하는 solution 함수를 완성해 주세요.
제한사항
- 1 ≤
myString
≤ 1000 - 1 ≤
pat
≤ 10
입출력 예
myString | pat | result |
---|---|---|
"banana" | "ana" | 2 |
"aaaa" | "aa" | 3 |
입출력 예 설명
입출력 예 #1
- "banana"에서 1 ~ 3번 인덱스에서 한 번, 3 ~ 5번 인덱스에서 또 한 번 "ana"가 등장해서 총 두 번 등장합니다. 따라서 2를 return 합니다.
입출력 예 #2
- "aaaa"에서 0 ~ 2번 인덱스에서 한 번, 1 ~ 3번 인덱스에서 한 번, 2 ~ 4번 인덱스에서 한 번 "aa"가 등장해서 총 세 번 등장합니다. 따라서 3을 return 합니다.
문제 풀이
코드 설명
- 코드의 목적:
- 주어진 문자열(myString)에서 특정 문자열(pat)이 등장하는 횟수를 찾아 반환
- 코드의 주요 구조:
- Solution 클래스와 solution 메소드로 구성
- solution 메소드에서 for loop와 startsWith 메소드를 사용하여 특정 문자열이 등장하는 횟수를 계산
- 코드의 주요 알고리즘:
- for loop를 사용하여 문자열을 순회하며 특정 위치에서 시작하는 부분 문자열이 특정 문자열과 일치하는지 확인
- startsWith 메소드를 사용하여 특정 위치에서 시작하는 부분 문자열이 특정 문자열과 일치하는지 확인
- 코드의 핵심:
- 주어진 문자열에서 특정 문자열이 등장하는 횟수를 찾는 것
- startsWith 메소드 등을 효율적으로 사용
풀이
class Solution {
// solution 메소드 정의, 문자열과 특정 문자열을 매개변수로 받음
public int solution(String myString, String pat) {
// 특정 문자열이 등장하는 횟수를 저장할 변수 선언
int answer = 0;
// 문자열을 순회하며 특정 위치에서 시작하는 부분 문자열이 특정 문자열과 일치하는지 확인
for (int i = 0; i <= myString.length() - pat.length(); i++) {
// 특정 위치에서 시작하는 부분 문자열이 특정 문자열과 일치하면 횟수를 증가
if (myString.startsWith(pat, i)) {
answer++;
}
}
// 특정 문자열이 등장하는 횟수를 반환
return answer;
}
}
'Coding > Programers' 카테고리의 다른 글
[ Programmers ] 공백으로 구분하기 1 ( java ) 84 / 124 (0) | 2024.01.08 |
---|---|
[ Programmers ] ad 제거하기 ( java ) 83 / 124 (0) | 2024.01.08 |
[ Programmers ] 특정 문자열로 끝나는 가장 긴 부분 문자열 찾기 ( java ) 81 / 124 (0) | 2024.01.08 |
[ Programmers ] 특정한 문자를 대문자로 바꾸기 ( java ) 80 / 124 (0) | 2024.01.07 |
[ Programmers ] A 강조하기 ( java ) 79 / 124 (0) | 2024.01.07 |