일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Stack
- 프로그래머스 java
- StringTokenizer
- 18111번 마인크래프트 - java 구현
- mysql hy000 에러
- hash
- 백준 14938번 서강그라운드
- 백준 1647번 도시 분할 계획 - java
- 백준 2473번 세 용액 - java
- 백준 2467번 용액 자바 - 이분탐색
- HashMap
- 백준 1541
- HashSet
- StringBuilder
- 백준 1806번 부분합 java
- 최소 힙 1927
- ac 5430번
- 백준 1197번 최소 스패닝 트리 - java
- kotlin
- 프로그래머스 자바
- dp
- Java
- 코틀린기초
- 백준 3190번
- append
- 프로그래머스
- toUpperCase
- map
- replace()
- 백준 1043번 거짓말 - java 분리 집합
Archives
- Today
- Total
말하는 컴공감자의 텃밭
프로그래머스 JadenCase 문자열 만들기 <2점> - 자바(java) 본문
728x90
JadenCase 구현 문제다.
toUpperCase와 toLowerCase 두개 메인으로 사용한다 치고 예외처리를 생각해봤다.
먼저 첫 문자가 알파벳이 아닐때는 그대로 소문자로 두는 경우 고려해야하고. 공백을 고려하면 된다.
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 | import java.util.*; class Solution { public String solution(String s) { StringBuilder sb = new StringBuilder(); s = s.toLowerCase(); // 초기에 모두 소문자로 변환. if (s.charAt(0) >= 'a' && s.charAt(0) <= 'z') { // 맨 처음 예외처리 sb.append(Character.toUpperCase(s.charAt(0))); }else sb.append(s.charAt(0)); for (int i = 1; i < s.length(); i++) { // 첫번째 이후, 앞에 공백이 있고, 알파뱃이라면 대문자로 변환. if (s.charAt(i - 1) == ' ') { if (s.charAt(i) >= 'a' && s.charAt(i) <= 'z') { sb.append(Character.toUpperCase(s.charAt(i))); } else { sb.append(s.charAt(i)); } } else { sb.append(s.charAt(i)); } } return sb.toString(); } } | cs |
간단쓰
728x90
'알고리즘 > Programmers - Java' 카테고리의 다른 글
프로그래머스 예상대진표 <4점> - 자바(java) (0) | 2023.06.28 |
---|---|
프로그래머스 올바른괄호 <2점> - 자바(java) Stack (0) | 2023.06.27 |
프로그래머스 햄버거 만들기 <7점>- 자바(java) Stack (0) | 2023.06.23 |
프로그래머스 안전지대 <2점> - 자바(java) (0) | 2023.06.18 |
프로그래머스 테이블 해시 함수 <level2> - 자바(java) 2차원배열 정렬, XOR 연산 (1) | 2023.06.17 |
Comments