首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

【递归】递归求n个数中的最大值

作者:每天都要记得刷题(●’◡’●) 时间:2022/04/04 本篇感悟:举一反,由求 n的阶乘联想到递归求n个数中的最大值,对递归有了更深的了解。...文章目录 ⭐题目(代码在文末) ⭐递归思想 ⭐求前n个斐波那契数 ⭐具体代码(答案) ⭐题目(代码在文末) 使用递归求 55 ,22, 155, 77, 99这5个数中的最大值 ⭐递归思想 Q...往里套用就是: 关键:重复把求最大值这个过程重复再重复,知道找到递归出口 1.当数组只有一个元素的时候,这个数就是最大值 2.但是当n>1时,从数组下标大的一端开始自身调用**,将最后一个数和n-...1个数中的最大值进行比较(假设我们已知)** 3.然后就是求n-1个数中的最大值,也就是重复了以上的步骤 4.知道我们到了递归出口,再归回去就可以了。...a[n - 1] : find_max(a, n - 1); } int main() { //递归求n个数中的最大值 int a[5] = { 55,22,155,77,99 }; int

1.2K20

个数组中找最大值和最小值

给定一个数组,在这个数组中找到最大值和最小值。 最近在看一点算法书,看到分治法经典的金块问题,实质就是在一个数组中找到最大值和最小值的问题。...我们用分治法来做,先把数据都分成两两一组,如果是奇数个数据就剩余一个一组。...如果是偶数个数据,就是两两一组,第一组比较大小,分别设置为max和min,第二组来了自己本身内部比较大小,用大的和max进行比较,决定是否更新max,小的同样处理,以此类推。...如果是奇数个数据,就把min和max都设为单个的那个数据,其他的类似上面处理。 书上说可以证明,这个是在数组中(乱序)找最大值和最小值的算法之中,比较次数最少的算法。...//这是一中分治法,这是在寻找最大值和最小值比较次数最小的方法。

2.5K10

Java中获取一个数组的最大值和最小值

1,首先定义一个数组; //定义数组并初始化 int[] arr=new int[]{12,20,7,-3,0}; 2,将数组的第一个元素设置为最大值或者最小值; int max=arr[0...];//将数组的第一个元素赋给max int min=arr[0];//将数组的第一个元素赋给min 3,然后对数组进行遍历循环,若循环到的元素比最大值还要大,则将这个元素赋值给最大值;同理,若循环到的元素比最小值还要小...,则将这个元素赋值给最小值; for(int i=1;i<arr.length;i++){//从数组的第二个元素开始赋值,依次比较 if(arr[i]>max){//如果arr[i]大于最大值...,就将arr[i]赋给最大值 max=arr[i]; } if(arr[i]<min){//如果arr[i]小于最小值,就将arr[i]赋给最小值...min=arr[i]; } } 4,输出结果; System.out.println("最大值是:"+max); System.out.println("最小值是:"+min);

6.2K20

【LeetCode 239.滑动窗口最大值种解法

题目描述:给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。返回滑动窗口中的最大值。...输入: nums = [1,3,-1,-3,5,3,6,7], 和 k = 3 输出: [3,3,5,5,6,7] 解法 1:暴力法 这题其实暴力法时间效率也很高,直接移动这个滑动窗口,每次统计窗口中的最大值即可...这里简单说下重要的点:将数组分成大小相等的块,每个块都可以理解为有两个数组 left 和 right。left 方向从左到右,right 相反。...假设滑动窗口的范围是[i, j],很容易看出来,滑动窗口中的最大值就是 max(right[i], left[j])。...这里记录下重要的点: 双端队列中保存的是元素下标,方便判断元素是否在当前滑动窗口中 双端队列头元素对应的数字,就是当前滑动窗口的最大值 双端队列头尾出入元素的时间复杂度是$O(1)$ 本题的双端队列用到功能

70030
领券