PHP不確定層級(jí)數(shù)量的循環(huán)嵌套用什么思路解決?
問題描述
問題描述:以下數(shù)字全部是傳參1、給出未知個(gè)數(shù)的產(chǎn)品價(jià)格區(qū)間和可銷售最大數(shù)量最低售價(jià) 最高售價(jià) 最大數(shù)量產(chǎn)品A 1105 1115 29產(chǎn)品B 1605 1620 33產(chǎn)品C 2005 2025 172、給出本單銷售固定的銷售總額14850
以上問題的post傳參可以表現(xiàn)為:
$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;
求:有多少種組合銷售并返回?cái)?shù)組?重點(diǎn)是每次傳參的一維數(shù)量不確定,即可能有100種產(chǎn)品需要計(jì)算。
如果直接寫死的話是很簡(jiǎn)單,但是根本無法封裝:
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>"; } }} } } }}
問題就在于傳入產(chǎn)品的種類數(shù)量不確定性,這種不確定要循環(huán)多少次的,用什么思路來解決?
問題解答
回答1:如果不確定層級(jí)用嵌套循環(huán)不是個(gè)好主意
相關(guān)文章:
1. 編輯成功不顯示彈窗2. 哭遼 求大佬解答 控制器的join方法怎么轉(zhuǎn)模型方法3. Navicat for mysql 中以json格式儲(chǔ)存的數(shù)據(jù)存在大量反斜杠,如何去除?4. mysql - 數(shù)據(jù)庫(kù)表中,兩個(gè)表互為外鍵參考如何解決5. mysql儲(chǔ)存json錯(cuò)誤6. mysql - 怎么生成這個(gè)sql表?7. mysql - 表名稱前綴到底有啥用?8. sql語句 - 如何在mysql中批量添加用戶?9. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實(shí)現(xiàn)存在即更新應(yīng)該使用哪個(gè)標(biāo)簽?10. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。
