[TIL] 카테고리/알고리즘 문제풀기
[자바스크립트] 프로그래머스 Lv.1 시저 암호
티레이니
2022. 5. 18. 09:53
let answer = ''
let lowerCases = 'abcdefghijklmnopqrstuvwxyz' // 소문자 배열 생성
let upperCases = lowerCases.toUpperCase() // 대문자 배열 생성
s = s.split('') // 우선 주어진 문자열을 쪼개고
for (i=0; i<s.length; i++) { //문자열 길이만큼
if (s[i] === ' ') { continue } // 공백은 패스한다
else if (s[i] === s[i].toUpperCase()) { //대문자일경우, 대문자 배열에서 s[i]의 인덱스 + 4 번째 알파벳을 찾아 돌려준다
s[i] = upperCases[(upperCases.indexOf(s[i])+n)%26]
} else { // 소문자일경우, 소문자 배열에서 같은 작업
s[i] = lowerCases[(lowerCases.indexOf(s[i])+n)%26]
}
}
s = s.join('') // 다시 문자열로 합친다.
주어진 문자열을 시저 암호로 바꾸는 문제.
인덱스 번호를 밀기만 하면 되어서 어렵진 않았는데
소문자랑 대문자를 한번에 처리할 방법은 없었을까 고민하게된다.
https://programmers.co.kr/learn/courses/30/lessons/12926
코딩테스트 연습 - 시저 암호
어떤 문장의 각 알파벳을 일정한 거리만큼 밀어서 다른 알파벳으로 바꾸는 암호화 방식을 시저 암호라고 합니다. 예를 들어 "AB"는 1만큼 밀면 "BC"가 되고, 3만큼 밀면 "DE"가 됩니다. "z"는 1만큼 밀
programmers.co.kr