https://school.programmers.co.kr/learn/courses/30/lessons/12926
import java.util.Scanner;
class Solution {
public String solution(String s, int n) {
char[] arr = s.toCharArray();
String answer = "";
for (char x : arr) {
if (Character.isLowerCase(x))x = (char) ((x+n -'a') % 26 + 'a');
else if (Character.isUpperCase(x)) x = (char) ((x+n -'A') % 26 + 'A');
answer += x;
}
return answer;
}
public static void main(String[] args) {
Solution T = new Solution();
Scanner in = new Scanner(System.in);
String s = in.nextLine();
int n = in.nextInt();
System.out.println(T.solution(s,n));
}
}
문자열을 받아서 문자 하나식 쪼갠 후에 밀어줄때 z나 Z를 넘어가면 알파벳 범위를 넘어버려서
기존 문자열 + 밀 카운트에서 대,소문자를 구별해서 맨 대소문자 그룹 중 제일 작은 A나 a를 뺀 값을 나누고 다시 A나 a를 더해주는 방식으로 문자를 밀었다
'알고리즘 이전 > 프로그래머스 1레벨' 카테고리의 다른 글
소수 찾기 (0) | 2023.09.21 |
---|---|
문자열 (0) | 2023.09.21 |
문자열 내림차순 정렬하기 (0) | 2023.09.20 |
문자열 내 마음대로 정렬하기 (0) | 2023.09.19 |
나누어 떨어지는 숫자 배열 (0) | 2023.09.19 |