古代中国の数学者、張秋堅が著書『蘇安経』で提起した数学的問題: 鶏 1 羽は 5 羽の価値があり、雌鶏 1 羽は 3 羽の価値があり、ひよこ 3 羽は 1 羽の価値がある。 100 ドルで鶏を 100 羽購入した場合、鶏、母親、ひよこの値段はいくらですか?
翻訳:
雄鶏に5元、鶏に3元、ひよこに3元、私は購入しました100元で鶏100羽、それぞれ何羽ですか?
以下では、PHP を使用して、3 つの方法でこの問題を解決します。
前提:
雄鶏 1 羽、雌鳥 1 羽、ひよこ 1 羽の場合、合計金額は次のようになります:...、不正解です。
雄鶏 1 羽、雌鶏 1 羽、ひよこ 2 羽の場合、合計金額は次のようになります:...、不正解です。
雄鶏 1 羽、雌鳥 1 羽、ひよこ 3 羽の場合、合計金額は次のようになります:...、不正解です。
................................
雄鶏が 1 羽、雌鶏が 2 羽いる場合、鶏 1 羽に対して、少額のお金がかかります。 、合計価格は次のとおりです:...、間違っています。
雄鶏 1 羽、雌鶏 2 羽、ひよこ 2 羽の場合、合計金額は次のようになります:...、不正解です。
雄鶏 1 羽、雌鶏 2 羽、ひよこ 3 羽の場合、合計金額は次のようになります:...、不正解です。
................................
100 羽の雄鶏と 100 羽の雌鳥、100 羽のひよこがいる場合、合計価格は次のとおりです:...、間違っています。
この種のプログラミングのアイデアは「網羅的」と呼ばれます。これは、考えられるすべての答えをリストアップし、それを 1 つずつ検証することを意味します。
コードは次のとおりです:
<?php $count = 0; for($gongji = 0;$gongji <= 100;$gongji++){ for ($muji=0; $muji <= 100; $muji++) { for ($xiaoji=0; $xiaoji <= 100 ; $xiaoji++) { if($gongji + $muji + $xiaoji ==100 && $gongji*5 + $muji*3 + $xiaoji / 3 == 100){ echo "<br>公鸡:$gongji,母鸡: $muji,小鸡: $xiaoji"; } $count++; } } } echo "<br>".$count;
結果:
雄鶏: 0、雌鳥: 25、ひよこ: 75雄鶏: 4 羽、雌鶏: 18 羽、ひよこ: 78 羽 雄鶏: 8 羽、雌鶏: 11 羽、ひよこ: 81 羽 雄鶏: 12 羽、雌鶏: 4 羽、ひよこ: 841030301
コードは次のとおりです
$count = 0; for($gongji = 0;$gongji <= 100 / 5;$gongji++){ for ($muji=0; $muji <= 100 / 3; $muji++) { $xiaoji = 100 - $gongji - $muji; if($gongji*5 + $muji*3 +$xiaoji / 3 == 100){ echo "<br>公鸡:$gongji,母鸡: $muji,小鸡: $xiaoji"; } $count++; } } echo "<br>".$count;
結果:
雄鶏: 0、雌鳥: 25、ひよこ: 75 雄鶏: 4、雌鶏:18羽、ひよこ:78羽 雄鶏:8羽、雌鶏:11羽、ひよこ:81羽 雄鶏:12羽、雌鶏:4羽、ひよこ:84714
コード
$count = 0; for($gongji = 0;$gongji <= 100 / 5;$gongji++){ for ($muji=0; $muji <= (100-$gongji*5) / 3; $muji++) { $xiaoji = 100 - $gongji - $muji; if($gongji*5 + $muji*3 +$xiaoji / 3 == 100){ echo "<br>公鸡:$gongji,母鸡: $muji,小鸡: $xiaoji"; } $count++; } } echo "<br>".$count;
結果:
雄鶏: 0、雌鳥: 25、ひよこ: 75 雄鶏: 4 、雌鶏: 18、ひよこ: 78 雄鶏: 8、鶏: 11、ひよこ: 81 雄鶏: 12、雌鶏: 4、ひよこ: 84364
要約:
トリプル for ループを直接使用することは簡単に考えられます。ただし、トリプル for ループの複雑さが大きすぎるため、ループを減らすことを検討する必要があります。ニワトリの総数からオンドリとニワトリを差し引くだけで、ループの層が 1 つ減ります。これにより、実行時間が短縮され、コード効率が向上します。
以上がPHP 百貨百鶏問題 (3 つの問題解決のアイデアと答え)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。