my_string은 "3 + 5"처럼 문자열로 된 수식입니다. 문자열 my_string이 매개변수로 주어질 때, 수식을 계산한 값을 return 하는 solution 함수를 완성해주세요.
부호와 숫자 배열을 따로 나누어 계산을 해주었다.
function solution(my_string) {
let answer = my_string.split(" ");
let number = answer.filter((el) => el !== "+" && el !== "-");
let etc = answer.filter((el) => el === "+" || el === "-");
let res = Number(number[0]);
for (let i = 0; i < etc.length; i++) {
if (etc[i] === "+") {
res += Number(number[i + 1]);
} else {
res -= Number(number[i + 1]);
}
}
return res;
}
정수 배열 numbers가 매개변수로 주어집니다. numbers의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요.
function solution(my_string) {
let result = [];
for (let i = 0; i < my_string.length - 1; i++) {
for (let j = i + 1; j < my_string.length; j++) {
result.push(my_string[i] * my_string[j]);
}
}
return Math.max(...result);
}
이진수를 의미하는 두 개의 문자열 bin1과 bin2가 매개변수로 주어질 때, 두 이진수의 합을 return하도록 solution 함수를 완성해주세요.
parseInt
와 toString
으로 간단하게 푸는 방법도 있었지만 노가다를 해보았다.
10진수로 변환하여 더한 후 이진수로 다시 변환해주었다.
function solution(bin1, bin2) {
let rev1 = [...bin1].reverse();
let rev2 = [...bin2].reverse();
let res1 = 0;
let res2 = 0;
for (let i = 0; i < bin1.length; i++) {
res1 += Number(rev1[i] * 2 ** i);
}
for (let i = 0; i < bin2.length; i++) {
res2 += Number(rev2[i] * 2 ** i);
}
let sum = res1 + res2;
let answer = "";
if (res1 === 0 || res2 === 0) {
answer = "0";
}
while (sum >= 1) {
if (sum === 0) return 0;
answer += sum % 2;
sum = ~~(sum / 2);
}
return [...answer].reverse().join("");
}