# Level 0. 대문자와 소문자
대문자와 소문자
문제 설명
문자열 my_string이 매개변수로 주어질 때, 대문자는 소문자로 소문자는 대문자로 변환한 문자열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 1,000
- my_string은 영어 대문자와 소문자로만 구성되어 있습니다.
문제 풀이
1
2
3
4
5
6
7
8
9
10
11
12 | function solution(my_string) {
let answer = "";
for (let i = 0; i < my_string.length; i++) {
const asciiNum = my_string[i].charCodeAt();
if (asciiNum <= 90) {
answer += String.fromCharCode(asciiNum + 32);
} else {
answer += String.fromCharCode(asciiNum - 32);
}
}
return answer;
}
|
- 요구사항대로 구현함.
- 정규표현식과 아스키코드 사이에서 고민했으나 정규표현식을 사용하면 직관적일 수 있으나, 아스키코드가 성능상으로 낫다고 판단하였음.
# Level 0. 배열 원소의 길이
배열 원소의 길이
문제 설명
문자열 배열 strlist가 매개변수로 주어집니다. strlist 각 원소의 길이를 담은 배열을 retrun하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ strlist 원소의 길이 ≤ 100
- strlist는 알파벳 소문자, 대문자, 특수문자로 구성되어 있습니다.
문제 풀이
1
2
3 | function solution(strlist) {
return strlist.map((str) => str.length);
}
|
# Level 0. 삼각형의 완성 조건 (1)
삼각형의 완성조건 (1)
문제 설명
선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.
가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
삼각형의 세 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 세 변으로 삼각형을 만들 수 있다면 1, 만들 수 없다면 2를 return하도록 solution 함수를 완성해주세요.
제한사항
- sides의 원소는 자연수입니다.
- sides의 길이는 3입니다.
- 1 ≤ sides의 원소 ≤ 1,000
문제 풀이
1
2
3
4
5
6
7
8
9
10
11
12 | function solution(sides) {
const max = Math.max(...sides);
const maxIndex = sides.indexOf(max);
const answer =
sides.reduce((acc, curr, index) => {
if (index === maxIndex) return acc;
return acc + curr;
}) > max
? 1
: 2;
return answer;
}
|
- 요구사항대로 구현함.
- 최대값과 최대 값의 위치를 찾고, 나머지를 더하여 비교한 결과를 반환함.
- 배열의 길이가 3 밖에 되지 않으니 그냥 일일히 비교하는게 직관적이고 간단할 수는 있으나, 소프트웨어와 어울리지 않아서 이와 같이 풀이함.
# Level 0. 중복된 문자 제거
중복된 문자 제거
문제 설명
문자열 my_string이 매개변수로 주어집니다. my_string에서 중복된 문자를 제거하고 하나의 문자만 남긴 문자열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ my_string ≤ 110
- my_string은 대문자, 소문자, 공백으로 - 구성되어 있습니다.
- 대문자와 소문자를 구분합니다.
- 공백(“ “)도 하나의 문자로 구분합니다.
- 중복된 문자 중 가장 앞에 있는 문자를 남깁니다.
문제 풀이
1
2
3 | function solution(my_string) {
return [...new Set(my_string.split(""))].join("");
}
|
# Level 0. 암호 해독
암호 해독
문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
암호화된 문자열 cipher를 주고받습니다.
그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.
문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ cipher의 길이 ≤ 1,000
- 1 ≤ code ≤ cipher의 길이
- cipher는 소문자와 공백으로만 구성되어 있습니다.
- 공백도 하나의 문자로 취급합니다.
문제 풀이
1
2
3
4
5
6
7 | function solution(cipher, code) {
let answer = "";
for (let i = 0; i < cipher.length; i++) {
if ((i + 1) % code === 0) answer += cipher[i];
}
return answer;
}
|
- 요구사항대로 구현함.
- cipher에 split을 사용하고 forEach를 사용하는 방법도 있었으나, 이정도의 문제 풀이에서 그정도의 순수성을 지키지는 않아도 된다고 판단했음.