[BaekJoon] 2579๋ฒˆ ๊ณ„๋‹จ ์˜ค๋ฅด๊ธฐ

2022. 6. 2. 11:49ยท๐Ÿ’ฏ CodingTest/BaekJoon

โ–ถ ๋ฌธ์ œ : http://acmicpc.net/problem/2579

 

2579๋ฒˆ: ๊ณ„๋‹จ ์˜ค๋ฅด๊ธฐ

๊ณ„๋‹จ ์˜ค๋ฅด๊ธฐ ๊ฒŒ์ž„์€ ๊ณ„๋‹จ ์•„๋ž˜ ์‹œ์ž‘์ ๋ถ€ํ„ฐ ๊ณ„๋‹จ ๊ผญ๋Œ€๊ธฐ์— ์œ„์น˜ํ•œ ๋„์ฐฉ์ ๊นŒ์ง€ ๊ฐ€๋Š” ๊ฒŒ์ž„์ด๋‹ค. <๊ทธ๋ฆผ 1>๊ณผ ๊ฐ™์ด ๊ฐ๊ฐ์˜ ๊ณ„๋‹จ์—๋Š” ์ผ์ •ํ•œ ์ ์ˆ˜๊ฐ€ ์“ฐ์—ฌ ์žˆ๋Š”๋ฐ ๊ณ„๋‹จ์„ ๋ฐŸ์œผ๋ฉด ๊ทธ ๊ณ„๋‹จ์— ์“ฐ์—ฌ ์žˆ๋Š” ์ 

www.acmicpc.net

 

โ–ถ ์ฝ”๋“œ :

let input = require('fs').readFileSync(`BaekJoon/testcase.txt`).toString().split('\n');

const [N, ...temp] = input;
const stairs = temp.map(n => Number(n));
const dp = Array(N).fill(0);

dp[0] = stairs[0];
dp[1] = Math.max(stairs[0] + stairs[1], stairs[1]);
dp[2] = Math.max(stairs[0] + stairs[2], stairs[1] + stairs[2]);

for(let i = 3; i < N; i++){
    dp[i] = Math.max(stairs[i] + stairs[i-1] + dp[i-3], stairs[i] + dp[i-2]);
}

console.log(dp[N-1])

 

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

1. ๋™์  ํ”„๋กœ๊ทธ๋ž˜๋ฐ(DP)์„ ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ์ œ์ด๋‹ค. 

2. ์ดˆ๊ธฐ input์œผ๋กœ ๋“ค์–ด์˜จ ์ ์ˆ˜๋ฅผ stairs๋ฐฐ์—ด์— ์ €์žฅํ•œ๋‹ค. ๊ฐ ์ธต์—์„œ์˜ ์ตœ๋Œ€๊ฐ’์€ dp ๋ฐฐ์—ด์— ์ €์žฅํ•œ๋‹ค.

3. ์—ฐ์†๋œ 3์นธ์€ ์˜ค๋ฅผ ์ˆ˜ ์—†๊ณ , ๋งˆ์ง€๋ง‰ ๊ณ„๋‹จ์€ ๋ฐŸ์•„์•ผํ•œ๋‹ค. ๋˜ํ•œ ์ฒซ ์‹œ์ž‘์ด 0๋ฒˆ์งธ ์นธ์ด ์•„๋‹์ˆ˜๋„ ์žˆ๊ธฐ์— 0, 1, 2 ๋ฒˆ์งธ ๊ณ„๋‹จ์˜ ์ดˆ๊ธฐ๊ฐ’์„ ๊ณ„์‚ฐํ•ด์„œ ๋„ฃ์–ด์ค€๋‹ค. => Math.max() ์‚ฌ์šฉ

  - 0๋ฒˆ์งธ : stairs[0]์˜ ๊ฐ’์„ ๊ทธ๋Œ€๋กœ ๊ฐ€์ง„๋‹ค.

  - 1๋ฒˆ์งธ : stairs[1] ์˜ ๊ฐ’๊ณผ stairs[0] + stairs[1] ๊ฐ’, ์ฆ‰ ๋ฐ”๋กœ 1๋ฒˆ์งธ ์นธ์œผ๋กœ ๊ฐ€๋Š” ๊ฒฝ์šฐ์™€ 0๋ฒˆ์งธ ์นธ์„ ๋ฐŸ๊ณ  1๋ฒˆ์งธ ์นธ์„ ์˜ค๋ฅด๋Š” ๊ฒฝ์šฐ ์ค‘ ํฐ ๊ฐ’์„ ์ €์žฅํ•œ๋‹ค.

  - 2๋ฒˆ์งธ : ์—ฐ์†๋œ 3์นธ์„ ์˜ค๋ฅผ ์ˆ˜ ์—†๊ธฐ์—, stairs[0] + stairs[2] ์™€ stairs[1] + stairs[2] ์˜ ๊ฐ’ ์ค‘ ๋” ํฐ ๊ฐ’์„ ์ €์žฅํ•œ๋‹ค.

4. ์ดํ›„ 3๋ฒˆ์งธ ์นธ๋ถ€ํ„ฐ๋Š” ํ˜„์žฌ ์นธ์˜ ์ ์ˆ˜์™€ ์ด์ „ ์นธ์˜ ์ ์ˆ˜ ๊ทธ๋ฆฌ๊ณ  ์ด์ „ ์นธ์œผ๋กœ๋ถ€ํ„ฐ ํ•œ์นธ ๊ฑด๋„ˆ๋›ด i-3 ๋ฒˆ์งธ์˜ dp ๊ฐ’์„ ํ•ฉ์นœ ๊ฐ’๊ณผ ํ˜„์žฌ ์นธ์˜ ์ ์ˆ˜์™€ ์ „์ „์นธ๊นŒ์ง€(i-2)์˜ dp์— ์ €์žฅ๋œ ๊ฐ’์„ ํ•ฉ์นœ ๊ฐ’์„ ๋น„๊ตํ•œ๋‹ค. 

  - ์ด๋ ‡๊ฒŒ ๋˜๋ฉด ์—ฐ์†๋œ 3์นธ์„ ์˜ค๋ฅด๋Š” ๊ฒฝ์šฐ๋ฅผ ๋ฐฐ์ œํ•  ์ˆ˜ ์žˆ๊ธฐ๋•Œ๋ฌธ.

5. ๊ฒฐ๊ณผ์ ์œผ๋กœ stairs๋Š” ๊ฐ ์นธ์—์„œ์˜ ์ ์ˆ˜๋ฅผ ๋‚˜ํƒ€๋‚ด๋Š” ๋ฐฐ์—ด์ธ ๊ฒƒ์ด๊ณ , dp์— ์ €์žฅ๋œ ๊ฐ’์€ ์—ฐ์†๋œ 3์นธ์„ ์˜ค๋ฅด์ง€ ์•Š์œผ๋ฉด์„œ ๊ณ„๋‹จ์„ ์˜ฌ๋ž์„๋•Œ์˜ ์ตœ๋Œ€๊ฐ’์„ ์ €์žฅํ•œ ๋ฐฐ์—ด์ด๋ผ๊ณ  ์ƒ๊ฐํ•  ์ˆ˜ ์žˆ๋‹ค.

6. ์—ฐ์‚ฐ ํ›„ ๊ฒฐ๊ณผ๋ฅผ ์ถœ๋ ฅํ•˜๋ฉด ๋„์•

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

[BaekJoon] 11724๋ฒˆ ์—ฐ๊ฒฐ ์š”์†Œ์˜ ๊ฐœ์ˆ˜  (0) 2022.06.03
[BaekJoon] 2606๋ฒˆ ๋ฐ”์ด๋Ÿฌ์Šค  (0) 2022.06.02
[Baekjoon] 1764 ๋“ฃ๋ณด์žก  (0) 2022.05.27
[Baekjoon] 1676 ํŒฉํ† ๋ฆฌ์–ผ 0์˜ ๊ฐœ์ˆ˜  (0) 2022.05.27
[Baekjoon] 1389๋ฒˆ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 6๋‹จ๊ณ„ ๋ฒ•์น™  (0) 2022.05.27
'๐Ÿ’ฏ CodingTest/BaekJoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [BaekJoon] 11724๋ฒˆ ์—ฐ๊ฒฐ ์š”์†Œ์˜ ๊ฐœ์ˆ˜
  • [BaekJoon] 2606๋ฒˆ ๋ฐ”์ด๋Ÿฌ์Šค
  • [Baekjoon] 1764 ๋“ฃ๋ณด์žก
  • [Baekjoon] 1676 ํŒฉํ† ๋ฆฌ์–ผ 0์˜ ๊ฐœ์ˆ˜
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)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

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

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

    • ํƒœ๊ทธ

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

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    [BaekJoon] 2579๋ฒˆ ๊ณ„๋‹จ ์˜ค๋ฅด๊ธฐ
    ์ƒ๋‹จ์œผ๋กœ

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

    ๋‹จ์ถ•ํ‚ค

    ๋‚ด ๋ธ”๋กœ๊ทธ

    ๋‚ด ๋ธ”๋กœ๊ทธ - ๊ด€๋ฆฌ์ž ํ™ˆ ์ „ํ™˜
    Q
    Q
    ์ƒˆ ๊ธ€ ์“ฐ๊ธฐ
    W
    W

    ๋ธ”๋กœ๊ทธ ๊ฒŒ์‹œ๊ธ€

    ๊ธ€ ์ˆ˜์ • (๊ถŒํ•œ ์žˆ๋Š” ๊ฒฝ์šฐ)
    E
    E
    ๋Œ“๊ธ€ ์˜์—ญ์œผ๋กœ ์ด๋™
    C
    C

    ๋ชจ๋“  ์˜์—ญ

    ์ด ํŽ˜์ด์ง€์˜ URL ๋ณต์‚ฌ
    S
    S
    ๋งจ ์œ„๋กœ ์ด๋™
    T
    T
    ํ‹ฐ์Šคํ† ๋ฆฌ ํ™ˆ ์ด๋™
    H
    H
    ๋‹จ์ถ•ํ‚ค ์•ˆ๋‚ด
    Shift + /
    โ‡ง + /

    * ๋‹จ์ถ•ํ‚ค๋Š” ํ•œ๊ธ€/์˜๋ฌธ ๋Œ€์†Œ๋ฌธ์ž๋กœ ์ด์šฉ ๊ฐ€๋Šฅํ•˜๋ฉฐ, ํ‹ฐ์Šคํ† ๋ฆฌ ๊ธฐ๋ณธ ๋„๋ฉ”์ธ์—์„œ๋งŒ ๋™์ž‘ํ•ฉ๋‹ˆ๋‹ค.