求数组的最大值最小值

算法数组中的最大值和最小值

方法1:遍历两次求出最大值最小值 ,时间复杂度N*2

方法2:相邻两个数分为一组比较,大的放在偶数位,小的放到奇数位,然后在偶数位上找到最大值,在奇数位上找到最小值N*1.5

方法3:定义两个变量Max,Min值,相邻两个数分为一组,比较出最大值和最小值,最大值和Max比较,是否大于Max,如果大于赋值于Max,最小值和Min比较,是否小于Min,如果小于赋值于Min

方法4:递归方法,分别求出前后N/2个数的Min和Max

 

代码:

(Max,Min)Search(arr, b, e) 

{ 
     If(e-b<=1) 
     { 

        If(arr[b]<arr[e]) 

        { 

           Return arr[e], arr[b]; 

        } 

        Else 

        { 

          Return arr[b], arr[e]; 

        } 

     } 

     MaxL,MinL=Search(arr,b,b+(e-b)/2); 

     MaxR,MinR=Search(arr,b+(e-b)/2,e); 

     If(MaxL>MaxR) 

        maxV=maxL; 

     else 

        maxV=maxR; 

     if(minL<minR) 

        minV=minL; 

     else 

     minV=minR; 

     return  maxV,minV; 

}


扩展:
 求N个数组中,第二大的数:分别求出前后N/2中的最大值,比较返回较小的那个

在C#中,可以使用循环来数组最大值最小值。在给定的代码片段中,引用演示了如何找到数组最大值,而引用演示了如何找到数组最小值。 要找到数组最大值,可以使用以下步骤: 1. 首先,定义一个整数变量max,并将其初始化为数组的第一个元素a。 2. 然后,使用一个循环遍历数组中的每个元素。在循环中,从索引0开始,逐个增加索引i,直到i小于数组的长度a.Length。 3. 在循环体中,使用条件语句判断当前元素a[i]是否大于max。如果是,则更新max的值为当前元素a[i]。 4. 循环结束后,max的值将是数组最大值。 5. 最后,使用Console.WriteLine语句将max的值打印出来。 要找到数组最小值,可以使用类似的步骤: 1. 首先,定义一个整数变量min,并将其初始化为数组的第一个元素a。 2. 然后,使用一个循环遍历数组中的每个元素。在循环中,从索引0开始,逐个增加索引i,直到i小于数组的长度a.Length。 3. 在循环体中,使用条件语句判断当前元素a[i]是否小于min。如果是,则更新min的值为当前元素a[i]。 4. 循环结束后,min的值将是数组最小值。 5. 最后,使用Console.WriteLine语句将min的值打印出来。 所以,对于给定的数组{10, 9, 6, 4234, 312},最大值是4234,最小值是6。 而对于数组{10, 1, 5, 6123, 34},最大值是6123,最小值是1。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值