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 | 31 |
Tags
- Array.asList
- 스택
- 버블정렬
- 백준
- 알고리즘
- MySQL
- 투포인터알고리즘
- 구간합구하기
- Spring MVC 동작원리
- OOP
- vm인스턴스생성
- 백준 11659
- 프로그래머스
- 싱글톤패턴
- Spring Web MVC
- java
- 재귀함수
- 재귀와반복문
- List.of
- 코딩테스트
- 코드스테이츠 백엔드
- 성능테스트툴
- 코드스테이츠
- GCP
- 11659
- String.valueOf()
- 자바
- Spring MVC 구성요소
- 인텔리제이
- 클라우드에서 도커 실행하기
Archives
- Today
- Total
순간을 기록으로
[인프런] 대소문자 변환 | 문자열 본문
문제
풀이
- 매개변수로 입력받은 문자열을 한 문자씩 검삭한다.
- 만약 문자가 대문자라면 소문자로 바꾼다
- 만약 문자가 소문자라면 대문자로 바꾼다.
주의할 점은 문자열의 길이가 100이 나올 수 있다. 문자열을 붙이는 연산은 새로운 객체를 생성하는 작업이다. 따라서 StringBuilder를 사용해서 성능을 높이고 마지막에 String으로 변환한다.
소스코드1 - 아스키코드 성질을 이용한 풀이
package 인프런.문자열.대소문자변환.아스키코드이용;
import java.util.Scanner;
/*
* 대소문자 변환 문제
* 한 문자열을 입력받고 소문자는 대문자로 바꾸고 대문자는 소문자로 바꾸는 문제
* 우선 문자열의 길이만큼 반복해서 한 문자씩 처리할건데. 문자열이 아닌 문자 단위로 처리하므로 향상된 for문과 toCharArray()로 접근한다.
* 특정 문자가 소문자인걸 알려면 그 문자의 아스키 코드값을 알면된다. 그리고 아스키코드에서 소문자가 대문자보다 값이 작다.
* 특정 알파벳의 대문자 소문자 값차이는 32이다.
* 대문자에서 소문자로 만드려면 값을 -32해준다. 소문자에서 대문자를 만드려면 값을 32더해준다.
* 그리고 구한 문자들을 이어붙이기 위해 StringBuilder를 사용한다.
* */
public class Main {
public String solution(String str) {
StringBuilder sb = new StringBuilder();
for(char ch : str.toCharArray()) {
if('A' <= ch && ch <= 'Z'){ // 만약 대문자이면 // 부등호를 포함하는거 주의한다.
ch += 32;
sb.append(ch);
}
else if('a' <= ch && ch <= 'z'){ // 만약 소문자이면
ch -= 32;
sb.append(ch);
}
}
return sb.toString();
}
public static void main(String[] args) {
Main T = new Main();
Scanner in = new Scanner(System.in);
String str = in.next();
System.out.println(T.solution(str));
}
}
소스코드2 - Character 함수 이용
package 인프런.문자열.대소문자변환.내장함수이용;
import java.util.Scanner;
/*
* 대소문자 변환 문제
* 한 문자열을 입력받고 소문자는 대문자로 바꾸고 대문자는 소문자로 바꾸는 문제
* 우선 문자열의 길이만큼 반복해서 한 문자씩 처리할건데. 문자열이 아닌 문자 단위로 처리하므로 향상된 for문과 toCharArray()로 접근한다.
* 특정 문자가 소문자인걸 알려면 그 문자의 아스키 코드값을 알면된다. 그리고 아스키코드에서 소문자가 대문자보다 값이 작다.
* 특정 알파벳의 대문자 소문자 값차이는 32이다.
* 대문자에서 소문자로 만드려면 값을 -32해준다. 소문자에서 대문자를 만드려면 값을 32더해준다.
* 그리고 구한 문자들을 이어붙이기 위해 StringBuilder를 사용한다.
* */
public class Main {
public String solution(String str) {
StringBuilder sb = new StringBuilder();
for(char ch : str.toCharArray()) {
if(Character.isLowerCase(ch)) // 소문자면 참
sb.append(Character.toUpperCase(ch));
else if(Character.isUpperCase(ch)) // 대문자면 참
sb.append(Character.toLowerCase(ch));
}
return sb.toString();
}
public static void main(String[] args) {
Main T = new Main();
Scanner in = new Scanner(System.in);
String str = in.next();
System.out.println(T.solution(str));
}
}
새로 배운 것
Character
public static boolean IsLowerCase(char ch): 소문자이면 참을 반환한다.
'Problem Solving' 카테고리의 다른 글
[Java] 단어 뒤집기 | 인프런 (0) | 2022.04.19 |
---|---|
[Java] 문장 속 가장 긴 단어 찾기 | 인프런 (0) | 2022.04.19 |
[Java] 신고 결과 받기 | 프로그래머스 (0) | 2022.04.18 |
[Java] 나머지가 1이 되는 수 찾기 | 프로그래머스 (0) | 2022.04.18 |
[MySQL] 국가명이 들어간 수도명을 확장자와 분리하기 (0) | 2022.04.18 |
Comments