[프로그래머스] 코딩테스트 연습 - 연습문제 Level 1 시저 암호
Solution.java
class Solution {
public String solution(String s, int n) {
String answer = "";
char[] upper = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };
char[] lower = { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z' };
char[] tmp = s.toCharArray();
for (int i = 0; i < tmp.length; i++) {
if (Character.isUpperCase(tmp[i])) {
tmp[i] = upper[(tmp[i] - 'A' + n) % 26];
}
if (Character.isLowerCase(tmp[i])) {
tmp[i] = lower[(tmp[i] - 'a' + n) % 26];
}
}
answer = String.valueOf(tmp);
return answer;
}
}
class Solution {
public String solution(String s, int n) {
String answer = "";
char[] upper = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };
char[] lower = { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z' };
char[] tmp = s.toCharArray();
for (int i = 0; i < tmp.length; i++) {
if (Character.isUpperCase(tmp[i])) {
tmp[i] = upper[(tmp[i] - 'A' + n) % 26];
}
if (Character.isLowerCase(tmp[i])) {
tmp[i] = lower[(tmp[i] - 'a' + n) % 26];
}
}
answer = String.valueOf(tmp);
return answer;
}
}
다른 사람의 풀이를 보고 굳이 uppder, lower 배열들을 쓰지 않아도 된다는걸 배웠다.
upper[(tmp[i] - 'A' + n) % 26]대신에 (tmp[i] - 'A' + n) % 26 + 'A'를 해주면 된다.
출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges
Author And Source
이 문제에 관하여([프로그래머스] 코딩테스트 연습 - 연습문제 Level 1 시저 암호), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@hye07on11/프로그래머스-코딩테스트-연습-연습문제-Level-1-시저-암호저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)