몸과 마음이 건전한 SW 개발자

프로그래머스 [Lv. 2] 시소 짝꿍 {언어 : JavaScript} [꼭 다시 보기] 본문

알고리즘/꼭 다시 보기

프로그래머스 [Lv. 2] 시소 짝꿍 {언어 : JavaScript} [꼭 다시 보기]

스위태니 2024. 11. 15. 22:10

문제 링크

https://school.programmers.co.kr/learn/courses/30/lessons/152996

 

프로그래머스

SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr

정답 코드

function solution(weights) {
    const map = new Map();
    for (const w of weights) {
        if (map.has(w)) {
            map.set(w, map.get(w)+1);
        } else {
            map.set(w, 1);
        }
    }
    const answer = Array.from(map.keys()).reduce((sum, w) => {
        const cnt = map.get(w);
        if (cnt >= 2) {
            sum += (cnt * (cnt - 1)) / 2;
        }
        if (w * 2 % 3 === 0 && map.has(w * 2 / 3)) {
            sum += (cnt * map.get(w * 2 / 3));
        }
        if (map.has(w*2)) {
            sum += (cnt * map.get(w*2));
        }
        if (w * 3 % 4 === 0 && map.has(w * 3 / 4)) {
            sum += (cnt * map.get(w * 3 / 4));
        }
        return sum;
    }, 0);
    return answer;
}

풀이 방법

https://sound-programming.tistory.com/369

 

프로그래머스 [Lv. 2] 시소 짝꿍 {언어 : Java} [다시 풀어 보기]

문제 링크https://school.programmers.co.kr/learn/courses/30/lessons/152996 프로그래머스SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프programmers.co.kr정답 코드impor

sound-programming.tistory.com

  • 풀이 방법은 위와 동일하다.

느낀점

  • 속도가 자바보다 빠를줄은 몰랐다.
  • map함수가 비슷해서 속도 차이가 얼마 안날줄 알았는데... 이러면 개발할 때 자바스크립트로 서버를 구축해도 될지도?