3妹:2哥2哥,你有没有看到新闻:北京地铁事故中102人骨折!
2哥: 看到了,没想到坐个地铁还出事故了。
3妹:事故原因为雪天轨滑导致前车信号降级,紧急制动停车,后车因所在区段位于下坡地段,雪天导致列车滑行,未能有效制动,造成与前车追尾。
2哥: 又是该死的自然灾害,记得几年前郑州地铁就是暴雨出过一次事故。
3妹:是啊,下雪也容易出事故,要格外 注意安全,她在这次无人员死亡,不幸中的万幸了。
2哥: 恩,找出了原因最重要,也要找出道路上存在的安全隐患,防患于未然。
3妹:是的, 就像我的工作中,也要在上线前就找出代码中的bug. 否则也容易出事故!
2哥: 哈哈,3妹还会举一反三啦。那我来考一道关于找出峰值的题目吧~
1题目:
给你一个下标从 0 开始的数组 mountain 。你的任务是找出数组 mountain 中的所有 峰值。
以数组形式返回给定数组中 峰值 的下标,顺序不限 。
注意:
峰值 是指一个严格大于其相邻元素的元素。
数组的第一个和最后一个元素 不 是峰值。
示例 1:
输入:mountain = [2,4,4]
输出:[]
解释:mountain[0] 和 mountain[2] 不可能是峰值,因为它们是数组的第一个和最后一个元素。
mountain[1] 也不可能是峰值,因为它不严格大于 mountain[2] 。
因此,答案为 [] 。
示例 2:
输入:mountain = [1,4,3,8,5]
输出:[1,3]
解释:mountain[0] 和 mountain[4] 不可能是峰值,因为它们是数组的第一个和最后一个元素。
mountain[2] 也不可能是峰值,因为它不严格大于 mountain[3] 和 mountain[1] 。
但是 mountain[1] 和 mountain[3] 严格大于它们的相邻元素。
因此,答案是 [1,3] 。
提示:
3 1
2思路:
遍历,
遍历下标在 [1,n−2]内的所有数,如果其大于其左右两侧相邻数字,则把 i 加入答案。
3java代码:
class Solution {
public List findPeaks(int[] mountain) {
List ans = new ArrayList();
for (int i = 1; i mountain[i - 1] && mountain[i] > mountain[服务器托管网i + 1]) {
ans.add(i);
}
}
return ans;
}
}
服务器托管,北京服务器托管,服务器租用 http:/服务器托管网/www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
1,递归和非递归分别实现求第n个斐波那契数 2,编写一个函数实现n的k次方,使用递归实现 3,求n的阶乘, 答案 2,编写服务器托管网一个函数实现n的k次方,使用递归实现 int multiplication(int n, int k) { if (k == …