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
- 파이썬 반복문
- JavaScript
- 리액트 페이지 이동
- 파이썬 slice
- REACT
- 타입스크립트 리액트
- 프로그래머스
- 코딩테스트
- 리액트
- js
- 리액트 훅
- 리액트 프로젝트
- 내일배움캠프 프로젝트
- Next 팀 프로젝트
- 파이썬 for
- 내일배움캠프
- 파이썬 enumerate
- 리액트 팀 프로젝트
- 한글 공부 사이트
- React Hooks
- 내배캠 프로젝트
- 그리드 정렬
- useState
- typeScript
- 타입스크립트 props
- 타입스크립트
- 자바스크립트
- 파이썬 for in
- 파이썬 list
- 내일배움캠프 최종 프로젝트
Archives
- Today
- Total
aotoyae
[JS] 프로그래머스 : 둘만의 암호 155652, charCodeAt, fromCharCode 본문
📝 문제
두 문자열 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
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
'Coding Test' 카테고리의 다른 글
[JS] 프로그래머스 : 햄버거 만들기 133502, stack (0) | 2024.03.20 |
---|---|
[JS] 프로그래머스 : 명예의 전당(1) 138477 (0) | 2024.03.19 |
[JS] 프로그래머스 : 이진 변환 반복하기 70129, toString(), match, replace (0) | 2024.03.09 |
[JS] 프로그래머스 : JadenCase 문자열 만들기, charAt(0), 첫 글자 대문자로 바꾸기 (0) | 2024.03.07 |
[JS] 프로그래머스 : 최댓값과 최솟값 12989, min, max, ...arr (0) | 2024.03.07 |