こんにちは、今日は競プロをやっていて恥ずかしながら詰まったのでやり方を紹介します。
問題
円玉を 枚、 円玉を 枚、10 円玉を 枚持っています。 これらの硬貨の中から何枚かを選び、合計金額をちょうど 円にする方法は何通りありますか。
ただし、Xは10の倍数とする。
入力例
2
2
4
出力
1
答え
#include <iostream>
using namespace std;
int main(){
int A,B,C;
int X;
int count=0;
int SUM = 0;
cin >> A;
cin >> B;
cin >> C;
cin >> X;
for (int a = 0; a <= A; ++a) {
for (int b = 0; b <= B; ++b) {
for (int c = 0; c <= C; ++c) {
SUM=0;
SUM = 1000*a + 100*b + 10*c;
if (SUM == X) ++count;
}
}
}
cout << count <<endl;
}
解説
競技プログラミングの問題だから、3重ループを使ってはだめだと思ったあなた!
もう何も思いつかなかったら使うしかありません!
3重ループを使って愚直に全探索しちゃいましょう!
以上です。