[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ํƒ€๊ฒŸ ๋„˜๋ฒ„

2024. 5. 31. 23:49ยท๐Ÿ’ญ Problem Solving/C++

๋ฌธ์ œ

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

 

ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค

์ฝ”๋“œ ์ค‘์‹ฌ์˜ ๊ฐœ๋ฐœ์ž ์ฑ„์šฉ. ์Šคํƒ ๊ธฐ๋ฐ˜์˜ ํฌ์ง€์…˜ ๋งค์นญ. ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค์˜ ๊ฐœ๋ฐœ์ž ๋งž์ถคํ˜• ํ”„๋กœํ•„์„ ๋“ฑ๋กํ•˜๊ณ , ๋‚˜์™€ ๊ธฐ์ˆ  ๊ถํ•ฉ์ด ์ž˜ ๋งž๋Š” ๊ธฐ์—…๋“ค์„ ๋งค์นญ ๋ฐ›์œผ์„ธ์š”.

programmers.co.kr

ํ’€์ด

๐Ÿ’ก DFS, ์žฌ๊ท€ํ•จ์ˆ˜

  • ์ข…๋ฃŒ ์กฐ๊ฑด: numbers ๋ฐฐ์—ด์˜ ๋ชจ๋“  ์ˆ˜๋ฅผ ์„ ํƒ ์™„๋ฃŒ
  • ๋‹ค์Œ ์ธ๋ฑ์Šค๋กœ ๋„˜์–ด๊ฐ€๋ฉด์„œ + ๋˜๋Š” - ๋ฅผ ์„ ํƒํ•˜์—ฌ ์—ฐ์‚ฐํ•œ ๊ฐ’์„ ๋„˜๊ธด๋‹ค. 

์ฝ”๋“œ

#include <iostream>
#include <vector>

using namespace std;

int answer;

void dfs(int idx, int sum, int target, vector<int> &numbers) {
    if (idx == numbers.size()) {   // ์ข…๋ฃŒ ์กฐ๊ฑด: ๋ชจ๋“  ์ˆ˜ ํƒ์ƒ‰ ์™„๋ฃŒ
        if (sum == target) {    // target๊ณผ ๊ฐ™์œผ๋ฉด ๊ฒฝ์šฐ์˜ ์ˆ˜ + 1
            answer++;
        }
        return;
    }

    dfs(idx + 1, sum + numbers[idx], target, numbers);  // + ์„ ํƒ
    dfs(idx + 1, sum - numbers[idx], target, numbers);  // - ์„ ํƒ
}

int solution(vector<int> numbers, int target) {
    answer = 0;

    dfs(0, 0, target, numbers);

    return answer;
}

'๐Ÿ’ญ Problem Solving > C++' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ๋„คํŠธ์›Œํฌ  (0) 2024.06.04
[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ํฐ ์ˆ˜ ๋งŒ๋“ค๊ธฐ  (0) 2024.06.02
[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ์Šคํ‚ฌํŠธ๋ฆฌ  (0) 2024.05.31
[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ํ‚คํŒจ๋“œ ๋ˆ„๋ฅด๊ธฐ  (0) 2024.05.27
[BOJ][C++] ๋ฐฑ์ค€ 20546๋ฒˆ: ๐Ÿœ ๊ธฐ์ ์˜ ๋งค๋งค๋ฒ• ๐Ÿœ  (0) 2024.05.26
'๐Ÿ’ญ Problem Solving/C++' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ๋„คํŠธ์›Œํฌ
  • [ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ํฐ ์ˆ˜ ๋งŒ๋“ค๊ธฐ
  • [ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ์Šคํ‚ฌํŠธ๋ฆฌ
  • [ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ํ‚คํŒจ๋“œ ๋ˆ„๋ฅด๊ธฐ
0=2.
0=2.
  • 0=2.
    0=2
    0=2.
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (65)
      • ๐Ÿ“‚ Project (2)
        • Paint the City (2)
      • ๐Ÿ’ญ Problem Solving (28)
        • C++ (28)
      • ๐Ÿ“ Study (1)
        • React (1)
      • ๐Ÿ’ป CS (2)
        • ๐Ÿ“˜ Dev Book (2)
      • ๐Ÿƒ‍โ™€๏ธ Activities (32)
        • Web Front-End Basic Study (6)
        • 42 Cursus (26)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ํ™ˆ
    • ํƒœ๊ทธ
    • ๋ฐฉ๋ช…๋ก
    • ๊ธ€์“ฐ๊ธฐ
  • ๋งํฌ

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

  • ์ธ๊ธฐ ๊ธ€

  • ํƒœ๊ทธ

    dfs
    42๊ฒฝ์‚ฐ
    BFS
    ์ •๋ ฌ
    ์‹œ๋ฎฌ๋ ˆ์ด์…˜
    CS
    ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค
    git
    ๊ทธ๋ฆฌ๋”” ์•Œ๊ณ ๋ฆฌ์ฆ˜
    VR
    swea
    ๋ฐฑํŠธ๋ž˜ํ‚น
    ๊ตฌํ˜„
    ๋งต
    CSS
    JavaScript
    makefile
    github
    La Piscine
    .h
    dynamic programming
    C
    ๋ธŒ๋ฃจํŠธํฌ์Šค
    react
    knapsack
    ๋ฐฑ์ค€
    HTML
    unity
  • ์ตœ๊ทผ ๋Œ“๊ธ€

  • ์ตœ๊ทผ ๊ธ€

  • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.3
0=2.
[ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค][C++] ํƒ€๊ฒŸ ๋„˜๋ฒ„
์ƒ๋‹จ์œผ๋กœ

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