0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

「部分和問題」 競プロ例題 #1

Last updated at Posted at 2021-01-01

部分和問題

整数 a_1, a_2,・・・, a_n が与えられる。その中からいくつか選び、その和を丁度kにすることができるかを判定する。

例1
  • 入力
n=4
a={1,2,4,7}
k=13
  • 出力
Yes
例2
  • 入力
n=4
a={1,2,4,7}
k=15
  • 出力
No

アルゴリズム

a_1 から順に加えるかどうかを決め、n個全てについて決め終わったらその和がkに等しいかを判定する。

回答例


static int n = 4;
static int a[] = {1, 2, 4, 7};
static int k = 15;

//iまででsumを作って、残りi以降を調べる
static bool dfs(int i, int sum) {
    //n個決め終わったら、今までの和sumがkと等しいかを返す
    if ( i == n ) return sum == k;
    
    //a[i]を使わない場合
    if (dfs(i + 1, sum)) return true;
    
    //a[i]を使う場合
    if (dfs(i + 1, sum + a[i])) return true;
    
    //a[i]を使わないに関わらずkが作れないのでfalseを返す
    return false;
}

static void solve_partial_sum() {
    if (dfs(0 ,0)) printf("Yes\n");
    else printf("No\n");
}

main関数でsolve_partial_sum()関数を実行する。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?