数组递归取最大/小值 两种方式

	// 数组递归取最大值
			var arr = [20,60,80,[400,3200,100,200],1,[300,[10,400,[1000,30000,[340000]]]]];

			var temp = 0;
			var arrLength = 0;
			// 第一种
			function getMax(arr){
			    if(arr != null && arr.length > 0){
			        for( var i=0;i<arr.length;i++ ){
			        	var nowVal = arr[i];
			            if( !(nowVal instanceof Array) && temp<nowVal ){
			                temp = nowVal;
			            }else if( nowVal instanceof Array ){
			                getMax(nowVal);
			            }
			        }
			    }
			}
			getMax(arr);
			
			
			// 第二种
			function recursiveMax(input){
			    var nums=[];
			    for( var i=0; i<input.length; i++ ){
			        var obj=input[i];
			        if( obj instanceof Array ){
			            nums.push(recursiveMax(obj));
			        } else{
			            nums.push(obj);
			        }
			    }
			    return Math.max.apply(null,nums);
                //return Math.max.apply(null,nums);
			}
			console.log(recursiveMax(arr))
			

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值