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 |
Tags
- 리액트 프로젝트
- 타입스크립트 props
- REACT
- 자바스크립트
- 파이썬 enumerate
- 파이썬 for
- Next 팀 프로젝트
- 내일배움캠프
- 내배캠 프로젝트
- js
- tanstack query
- useState
- 파이썬 replace
- 리액트 훅
- typeScript
- 내일배움캠프 프로젝트
- JavaScript
- 파이썬 slice
- 파이썬 딕셔너리
- 내일배움캠프 최종 프로젝트
- React Hooks
- 타입스크립트
- 한글 공부 사이트
- 코딩테스트
- 리액트
- 파이썬 for in
- 파이썬 list
- 프로그래머스
- 파이썬 반복문
- 타입스크립트 리액트
Archives
- Today
- Total
sohyeon kim
[JS] 프로그래머스 : 둘만의 암호 155652, charCodeAt, fromCharCode 본문
728x90
📝 문제
두 문자열 s와 skip, 그리고 자연수 index가 주어질 때, 다음 규칙에 따라 문자열을 만들려 합니다. 암호의 규칙은 다음과 같습니다.
- 문자열 s의 각 알파벳을 index만큼 뒤의 알파벳으로 바꿔줍니다.
- index만큼의 뒤의 알파벳이 z를 넘어갈 경우 다시 a로 돌아갑니다.
- skip에 있는 알파벳은 제외하고 건너뜁니다.
예를 들어 s = "aukks", skip = "wbqd", index = 5일 때, a에서 5만큼 뒤에 있는 알파벳은 f지만 [b, c, d, e, f]에서 'b'와 'd'는 skip에 포함되므로 세지 않습니다. 따라서 'b', 'd'를 제외하고 'a'에서 5만큼 뒤에 있는 알파벳은 [c, e, f, g, h] 순서에 의해 'h'가 됩니다. 나머지 "ukks" 또한 위 규칙대로 바꾸면 "appy"가 되며 결과는 "happy"가 됩니다.
두 문자열 s와 skip, 그리고 자연수 index가 매개변수로 주어질 때 위 규칙대로 s를 변환한 결과를 return하도록 solution 함수를 완성해주세요.
🫠 나의 풀이
function solution(s, skip, index) {
let answer = '';
for (const i of s) {
let code = i.charCodeAt();
for (let j = 0; j < index; j++) {
code += 1;
if (code > 122) code = 97;
while (skip.includes(String.fromCharCode(code))) {
code += 1;
if (code > 122) code = 97;
}
}
answer += String.fromCharCode(code);
}
return answer;
}
🧞♂️ 다른 사람의 풀이
function solution(s, skip, index) {
const alphabet = ["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"].filter(c => !skip.includes(c));
return s.split("").map(c => alphabet[(alphabet.indexOf(c) + index) % alphabet.length]).join("");
}
🔗 https://school.programmers.co.kr/learn/courses/30/lessons/155652?language=javascript
728x90
반응형
'Coding Test' 카테고리의 다른 글
[Python] 프로그래머스 : 영어가 싫어요 120894, enumerate, keys (1) | 2024.04.04 |
---|---|
[Python] 프로그래머스 : 배열 만들기(4) 181918, while, list[-1] (0) | 2024.03.31 |
[JS] 프로그래머스 : 햄버거 만들기 133502, stack (0) | 2024.03.20 |
[JS] 프로그래머스 : 명예의 전당(1) 138477 (0) | 2024.03.19 |
[Python] 프로그래머스 : 문자열이 몇 번 등장하는지 세기 181871, startswith (0) | 2024.03.16 |