[Programmers] (Javascript) ์ˆ˜์‹ ์ตœ๋Œ€ํ™”

2022. 4. 25. 15:11ยท๐Ÿ’ฏ CodingTest/Programmers

https://programmers.co.kr/learn/courses/30/lessons/67257

 

์ฝ”๋”ฉํ…Œ์ŠคํŠธ ์—ฐ์Šต - ์ˆ˜์‹ ์ตœ๋Œ€ํ™”

IT ๋ฒค์ฒ˜ ํšŒ์‚ฌ๋ฅผ ์šด์˜ํ•˜๊ณ  ์žˆ๋Š” ๋ผ์ด์–ธ์€ ๋งค๋…„ ์‚ฌ๋‚ด ํ•ด์ปคํ†ค ๋Œ€ํšŒ๋ฅผ ๊ฐœ์ตœํ•˜์—ฌ ์šฐ์Šน์ž์—๊ฒŒ ์ƒ๊ธˆ์„ ์ง€๊ธ‰ํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์ด๋ฒˆ ๋Œ€ํšŒ์—์„œ๋Š” ์šฐ์Šน์ž์—๊ฒŒ ์ง€๊ธ‰๋˜๋Š” ์ƒ๊ธˆ์„ ์ด์ „ ๋Œ€ํšŒ์™€๋Š” ๋‹ค๋ฅด๊ฒŒ ๋‹ค์Œ๊ณผ

programmers.co.kr

 

โ–ถ ์ฝ”๋“œ : 

function solution(expression) {
    var orders = [
        ['*', '+', '-'],
        ['*', '-', '+'],
        ['+', '-', '*'],
        ['+', '*', '-'],
        ['-', '+', '*'],
        ['-', '*', '+'],
    ];
    let answer = -1;
    for (const order of orders){
        var res = parseInt(recursive(order,0,expression));

        res= Math.abs(res);
        
        if (res > answer)
        {
            answer = res;
        }
    }


    return answer;
}

function recursive(order,n, expr)
{
    if (n == 2)
    {
        return eval(expr);
    }
    else
    {
        if (order[n] == '*')
        {
            let temp = expr.split('*');
            let val = [];
            for (const e of temp)
            {
                val.push(recursive(order, n + 1, e));        
            }
            return eval(val.join('*'));
        }
        else if(order[n] == '-')
        {   
            let temp = expr.split('-');
            let val = [];
            for (const e of temp)
            {
                val.push(recursive(order, n + 1, e));        
            }
            return eval(val.join('-'));
        }
        else if(order[n] == '+')
        {
            let temp = expr.split('+');
            let val = [];
            for (const e of temp)
            {
                val.push(recursive(order, n + 1, e));        
            }
            return eval(val.join('+'));
        }
    }
    return temp;
}

 

โ–ถ ๋ฌธ์ œ ํ’€์ด : 

1. ๊ณ„์‚ฐ ์ˆœ์„œ๋ฅผ ์ €์žฅํ•˜๋Š” orders ๋ฐฐ์—ด์„ ์ƒ์„ฑํ•˜์˜€๋‹ค.

2. ๊ฐ๊ฐ์˜ ๊ณ„์‚ฐ์ˆœ์„œ์— ๋”ฐ๋ผ ๊ณ„์‚ฐ์„ ์ง„ํ–‰ํ•˜๊ณ , ๊ฒฐ๊ณผ๋ฅผ ๊ฐ€์ ธ์™€ ์ตœ์†Œ๊ฐ’์„ answer์— ์ €์žฅํ•˜์˜€๋‹ค.

3. recursiveํ•จ์ˆ˜๋ฅผ ํ†ตํ•ด ๊ณ„์‚ฐ์„ ์ง„ํ–‰ํ•œ๋‹ค.

  3-1) recursiveํ•จ์ˆ˜๋Š” n=2์ผ๋•Œ ์žฌ๊ท€๋ฅผ ์ข…๋ฃŒํ•œ๋‹ค.

  3-2) ๊ฐ๊ฐ์˜ order์— ์ €์žฅ๋œ ์—ฐ์‚ฐ์ž๋ฅผ ๊ธฐ์ค€์œผ๋กœ ๋‚˜๋ˆ„๊ณ  ์žฌ๊ท€๋ฅผ ํ†ตํ•ด ๋‚˜๋ˆ ์ง„ ํ‘œํ˜„์‹์—๋Œ€ํ•ด ๊ฐ™์€ ๊ณผ์ •์„ ๋ฐ˜๋ณตํ•œ๋‹ค.

  3-3) order์˜ ๋งˆ์ง€๋ง‰ ์—ฐ์‚ฐ์ด ์ข…๋ฃŒ๋จ์— ๋”ฐ๋ผ ์ˆœ์ฐจ์ ์œผ๋กœ ๋ฐ˜ํ™˜ํ•˜๊ณ , ์ดํ›„ ๋ฐ˜ํ™˜๋œ ๊ฒฐ๊ณผ ๋ฌธ์ž์—ด๋“ค์„ ๋‹ค์‹œ ๋‚˜๋ˆˆ ์—ฐ์‚ฐ์ž๋กœ            joinํ•˜์—ฌ ๊ฒฐ๊ณผ๋ฅผ ๊ณ„์‚ฐํ•œ๋‹ค.

 

'๐Ÿ’ฏ CodingTest > Programmers' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[Programmers] (Javascript) ์ถ”์„ ํŠธ๋ž˜ํ”ฝ  (0) 2022.04.26
[Programmers] (Javascript) ํŠœํ”Œ  (0) 2022.04.25
[Programmers] (Javascript) ๋‰ด์Šค ํด๋Ÿฌ์Šคํ„ฐ๋ง  (0) 2022.04.25
[Programmers] (Javascript) ๊ด„ํ˜ธ ๋ณ€ํ™˜  (0) 2022.04.25
[Programmers] (Javascript) ๊ฑฐ๋ฆฌ๋‘๊ธฐ ํ™•์ธํ•˜๊ธฐ  (0) 2022.04.21
'๐Ÿ’ฏ CodingTest/Programmers' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [Programmers] (Javascript) ์ถ”์„ ํŠธ๋ž˜ํ”ฝ
  • [Programmers] (Javascript) ํŠœํ”Œ
  • [Programmers] (Javascript) ๋‰ด์Šค ํด๋Ÿฌ์Šคํ„ฐ๋ง
  • [Programmers] (Javascript) ๊ด„ํ˜ธ ๋ณ€ํ™˜
S.Honey
S.Honey
  • S.Honey
    Algo ์“ฐ์ž
    S.Honey
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (123)
      • ํšŒ๊ณ  (0)
        • ์ทจ์—… ํ›„ ํšŒ๊ณ  (0)
      • ๐Ÿƒ Frontend Road-Map (2)
        • ๐Ÿšฉ Summary (1)
        • ๐Ÿ“š Road-Map Contents (1)
        • ๐ŸŸง HTML (0)
        • ๐ŸŸฆ CSS (0)
        • ๐ŸŸจ Javascript (0)
        • โฌœ React (0)
        • ๐ŸŸช Redux (0)
      • Backend (0)
        • QueryDSL (0)
      • ๐Ÿ’ป Programming Language (54)
        • C# (51)
        • Flutter-Dart (3)
        • Java (0)
      • ๐Ÿ“š Computer Science (4)
        • Algorithms (4)
        • Database (0)
        • Network (0)
        • Operating System(OS) (0)
      • ๐Ÿ’ฏ CodingTest (60)
        • BaekJoon (22)
        • Programmers (34)
        • CodeTree (4)
      • โœ’๏ธ Design Pattern (1)
      • ๐Ÿฑ Etc (2)
        • Jenkins Plugin ์ œ์ž‘๊ธฐ (1)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

    • ๊ณต์ง€์‚ฌํ•ญ

      • ๐Ÿ“– ๊ณต๋ถ€ ์ฐธ๊ณ  ๊ต์žฌ ๋ฐ ์ž๋ฃŒ
    • ์ธ๊ธฐ ๊ธ€

    • ํƒœ๊ทธ

      ์“ฐ์…จ์ž–์•„
      ์ด์ง„ํƒ์ƒ‰
      programmers
      ๊ทธ๋ž˜ํ”„ ํƒ์ƒ‰
      Algorithm
      c#
      ์•Œ๊ณ ๋ฆฌ์ฆ˜
      ์Šคํ„ฐ๋””
      BAEKJOON
      ๋™์  ํ”„๋กœ๊ทธ๋ž˜๋ฐ
      BFS
      ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค
      JS
      ๋ฌธ์ž์—ด ํŒŒ์‹ฑ
      sort
      ๊ตฌํ˜„
      DP
      ์‚ผ์„ฑsw์—ญํ…Œ
      ํŒŒ์ด์ฌ
      ์ฝ”๋”ฉํ…Œ์ŠคํŠธ
      ์ž๋ฃŒ๊ตฌ์กฐ
      ์ฝ”๋“œํŠธ๋ฆฌ
      ์‹œ๋ฎฌ๋ ˆ์ด์…˜
      DART
      Flutter
      ์นด์นด์˜ค
      ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      Java
      ๋ฐฑ์ค€
      JavaScript
    • ์ตœ๊ทผ ๋Œ“๊ธ€

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    [Programmers] (Javascript) ์ˆ˜์‹ ์ตœ๋Œ€ํ™”
    ์ƒ๋‹จ์œผ๋กœ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”