ホームページ > バックエンド開発 > C++ > C++ プログラミングを使用して、方程式 x + y + z <= n の解の数を求めます。

C++ プログラミングを使用して、方程式 x + y + z <= n の解の数を求めます。

王林
リリース: 2023-08-25 11:41:24
転載
1549 人が閲覧しました

使用C++编程,找到方程x + y + z <= n的解的数量

この記事では、方程式 x y z

Input: X = 1, Y = 1, Z = 1, n = 1

Output: 4

Input: X = 1, Y = 2, Z = 3, n = 4

Output: 3
ログイン後にコピー

この問題では、各変数を分離し、式 ( の値) を満たすかどうかを確認することで、すべての (x, y)、(y,z) を単純にループすることができます。 x、z)。

解決策

次に、総当たり法を使用して、指定された問題の解決策を見つけます。

ブルートフォースメソッド

このプログラムでは、方程式 z を満たすために、(x,y)、(y,z)、および (x,z) のすべての可能な値を調べます。 <= n - x - y (z は分離された変数)、0 <= z <= Z (他の分離された変数にも同じことが当てはまります)。 <= n - x - y(这里z是被分离的变量),其中0 <= z <= Z(其他被分离的变量也是一样)。


#include<bits/stdc++.h>
using namespace std;
int main(){
    int X = 1, Y = 2, Z = 3, n = 4; // limits of x, y, z and given n.
    int answer = 0; // counter variable.
    for(int i = 0; i <= X; i++){
        for(int j = 0; j <= Y; j++){
            int temp = (n - i) - j; // temp = n - x - y.
            if(temp >= Z){ // if n - x - y >= z so we increment the answer.
               answer++;
            }
        }
    }
    for(int i = 0; i <= X; i++){
        for(int j = 0; j <= Z; j++){
            int temp = (n - i) - j; // temp = n - x - y.
            if(temp >= Y){ // if n - x - y >= z so we increment the answer.
               answer++;
            }
        }
    }
    for(int i = 0; i <= Z; i++){
        for(int j = 0; j <= Y; j++){
            int temp = (n - i) - j; // temp = n - x - y.
            if(temp >= X){ // if n - x - y >= z so we increment the answer.
               answer++;
            }
        }
    }
    cout << answer << "\n";
}
ログイン後にコピー

出力

17
ログイン後にコピー

上記プログラムの説明

このプログラムでは、ネストされた for ループを使用して、すべての (x , y)、(y, z)、(x, z)を計算し、式が条件を満たしているかどうかを確認し、満たしている場合は答えを追加します。

結論

この記事では、時間計算量 O(X*Y で、方程式 x y z。また、この問題を解決するための C プログラムと完全な解決策も学びました。同じプログラムを C、Java、Python などの他の言語で書くことができます。

以上がC++ プログラミングを使用して、方程式 x + y + z <= n の解の数を求めます。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:tutorialspoint.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート