반응형
Notice
Recent Posts
Recent Comments
Link
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | ||||||
| 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 | 20 | 21 | 22 |
| 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 30 |
Tags
- 숫자 이어 붙이기
- 해결
- 142085
- PCCP
- 산 모양 타일링
- 싸피
- java
- 퍼즐 조각 채우기
- 수료
- softeer
- 카카오코드 본선
- 배열 돌리기 5
- 인턴십
- 오블완
- 14942
- SSAFY
- 프로그래머스
- 24955
- 10기
- 카카오
- 정기 코딩 인증평가
- 소프티어
- 핵심
- 설명
- 티스토리챌린지
- MySQL
- 등산코스 정하기
- 후기
- SQL
- 백준
Archives
- Today
- Total
개발 쥬스
[프로그래머스/Java] 12951 JadenCase 문자열 만들기 본문
반응형
🔗 문제 링크: https://school.programmers.co.kr/learn/courses/30/lessons/12951
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
🔍 해결 과정
주어진 문자열에서 공백의 상태는 그대로 유지를 한 채로 단어의 앞부분이 문자이면 해당 문자를 대문자로 바꾸고 그 뒤에 오는 문자열은 전부 소문자로 바꿔야 합니다.
간단한 구현 문제이긴 하나, 처음에 공백을 고려를 안 하고 코드를 구현하여 항상 예외 상황을 잘 고려해야 한다는 점을 다시 한번 각인시켜준 문제였습니다.
class Solution {
public String solution(String s) {
s = s.toLowerCase();
StringBuilder sb = new StringBuilder(s);
int len = s.length();
int idx = 0;
while (idx < len) {
while (idx < len && sb.charAt(idx) == ' ') {
++idx;
}
if (idx < len && 'a' <= sb.charAt(idx) && sb.charAt(idx) <= 'z') {
char up_c = Character.toUpperCase(sb.charAt(idx));
sb.deleteCharAt(idx);
sb.insert(idx, up_c);
}
while (idx < len && sb.charAt(idx) != ' ') {
++idx;
}
}
return sb.toString();
}
}
반응형
'알고리즘' 카테고리의 다른 글
| [프로그래머스/sql] 131529 카테고리 별 상품 개수 구하기 (0) | 2024.11.19 |
|---|---|
| [프로그래머스/Java] 70129 이진 변환 반복하기 (0) | 2024.11.18 |
| [프로그래머스/sql] 59047 이름에 el이 들어가는 동물 찾기 (2) | 2024.11.15 |
| [프로그래머스/Java] 181851 전국 대회 선발 고사 (0) | 2024.11.14 |
| [프로그래머스/Java] 181846 두 수의 합 (0) | 2024.11.14 |