PHP不確定層級數量的循環嵌套用什么思路解決?
問題描述
問題描述:以下數字全部是傳參1、給出未知個數的產品價格區間和可銷售最大數量最低售價 最高售價 最大數量產品A 1105 1115 29產品B 1605 1620 33產品C 2005 2025 172、給出本單銷售固定的銷售總額14850
以上問題的post傳參可以表現為:
$arr[0][‘low’]=1105;$arr[0][‘high’]=1115;$arr[0][‘num’]=29;$arr[1][‘low’]=1605;$arr[1][‘high’]=1620;$arr[1][‘num’]=33;$arr[2][‘low’]=2005;$arr[2][‘high’]=2025;$arr[2][‘num’]=17;$total=14850;
求:有多少種組合銷售并返回數組?重點是每次傳參的一維數量不確定,即可能有100種產品需要計算。
如果直接寫死的話是很簡單,但是根本無法封裝:
for ($a=1105; $a <= 1115; $a++) { for ($b=1605; $b <= 1620; $b++) { for ($c=2005; $c <= 2025 ; $c++) { for ($x=0; $x <= 19; $x++) {for ($y=0; $y <= 30 ; $y++) { for ($z=0; $z <= 10 ; $z++) { if ($a*$x + $b*$y +$c*$z == 14850) { echo $a."*".$x ."+". $b."*".$y."+". $c."*".$z."<br>"; } }} } } }}
問題就在于傳入產品的種類數量不確定性,這種不確定要循環多少次的,用什么思路來解決?
問題解答
回答1:如果不確定層級用嵌套循環不是個好主意
相關文章:
1. python - 獲取到的數據生成新的mysql表2. javascript - js 對中文進行MD5加密和python結果不一樣。3. mysql里的大表用mycat做水平拆分,是不是要先手動分好,再配置mycat4. window下mysql中文亂碼怎么解決??5. sass - gem install compass 使用淘寶 Ruby 安裝失敗,出現 4046. python - (初學者)代碼運行不起來,求指導,謝謝!7. 為啥不用HBuilder?8. python - flask sqlalchemy signals 無法觸發9. python的文件讀寫問題?10. 為什么python中實例檢查推薦使用isinstance而不是type?
