求這個(gè)多維數(shù)組中最小的值,輸出空白界面,看半天了也
不知道哪里有問(wèn)題。$nc 是內(nèi)層 nnc內(nèi)內(nèi)層
<?php
$arr1=array( 5,
array(3,5,6,7,8),
array(13,5,6,17,28),
array(31,5,76,7,38),
array(33,55,6,7,
array(
1,70,88
)));
$min=$arr1[0] [0];
$len=count($arr1);
for($i=0;$i<$len;++$i) {
$len2 = count($arr1[$i]);
if (is_array($arr1[$i])) {
for ($nc = 0; $nc < $len2; ++$nc) {
if ($arr1[$i][$nc] < $min) {
$min = $arr1[$i][$nc];
}
if (is_array($arr1[$i][$nc])) {
$len3 = count($arr1[$i][$nc]);
for ($nnc = 0; $nnc < $len3; ++$nnc) {
if ($arr1[$i][$nc][$nnc] < $min) {
$min = $arr1[$i][$nc][$nnc];
}
}
}
}
}
elseif($arr1[$i]<$min){
$min=$arr1[$i];
}
}
echo $min;
?>
大概看了你的代碼,局限性比較高。給定的數(shù)組只知道是多位數(shù)組,壓根不知道到底是多少維的。所以你這個(gè)for的數(shù)量就存在局限性。
你這需求可以借助function來(lái)解決。
貼個(gè)代碼,已經(jīng)在里面注釋了。不懂再評(píng)論哈
<?php
$array = [
5,
[3,4],
[5,6],
[7,8,
[5,
[0,
[-1,2]
]
]
],
-66,
[-77,0]
];
function arrayMin($array) {
//判斷數(shù)組是否是一維數(shù)組,是的話,直接用min函數(shù)取得最小值
if (count($array) == count($array, 1)) {
return min($array);
} else {
//多位數(shù)組,用foreach循環(huán)數(shù)組
foreach ($array as $key => $value) {
if (is_array($value)) {
//判斷是否為數(shù)組,是的話,重新調(diào)用本函數(shù)(這樣就不用考慮最初給定的$array到底是多少維的了)
$array[$key] = arrayMin($array[$key]);//直接返回最小值,方便后續(xù)的計(jì)算
}
}
return min($array);//經(jīng)過(guò)上面的循環(huán)計(jì)算,$array已經(jīng)只是個(gè)一維數(shù)組了
}
}
var_dump(arrayMin($array));
首先你這種寫法很丑, 而且一旦數(shù)據(jù)結(jié)構(gòu)發(fā)生變化, 你的代碼就不能用了.
其次, 你的寫法有可能會(huì)出現(xiàn)錯(cuò)誤的, 比如$len2 = count($arr1[$i]);
這一句
提幾個(gè)建議:
foreach
代替for
min
方法以下是我的示例:
/**
* @param array $array
* @return Generator
*/
function flatten_array(array $array): Generator {
foreach ($array as $member) {
if (is_array($member)) {
yield from flatten_array($member);
} else {
yield $member;
}
}
}
/**
* @param array $numbers
* @return int
*/
function find_min_number(array $numbers): int {
return min(...flatten_array($numbers));
}
echo find_min_number(array(5,
array( 3, 5, 6, 7, 8 ),
array( 13, 5, 6, 17, 28 ),
array( 31, 5, 76, 7, 38 ),
array( 33, 55, 6, 7,
array( 1, 70, 88 )
)
));
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過(guò)二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。