【华为OD题库C卷-001】山脉的个数

题目

给定一个数组,数组中的每个元素代表该位置的海拔高度。0表示平地,>=1时表示属于某个山峰,山峰的定义为当某个位置的左右海拔均小于自己的海拔时,该位置为山峰。数组起始位置计算时可只满足一边的条件。
输入描述

---个整数数组
输出描述

输出符合条件的山峰的个数
示例1:
输入:

0,1,2,3,2,4

输出:

2
示例2 :
输入:

3,0,3,4,1

输出:

2

思路

此题简单,直接循环比较每个点的前后位置是否均小于它即可。需要注意,虽然题目描述的是"数组起始位置计算时可只满足一边的条件",根据示例1,其实在终止位置也符合这一规律。通过"或"操作短路判断边界的情况

题解

java 复制代码
package hwodC;

import java.util.Arrays;
import java.util.Scanner;

public class ValidMountainCount_001 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String inputs = sc.nextLine();
        int[] nums = Arrays.stream(inputs.substring(1, inputs.length() - 1).split(",")).mapToInt(Integer::parseInt).toArray();
        System.out.println(validMountainCount(nums));

    }

    private static int validMountainCount(int[] nums) {
        int res = 0;
        for (int i = 0; i < nums.length; i++) {
            if ((i == 0 || nums[i] > nums[i - 1]) && (i == nums.length - 1 || nums[i] > nums[i + 1])) {
                res++;
            }
        }
        return res;
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

说明

本专栏所有文章均为原创,欢迎转载,请注明文章出处:https://blog.csdn.net/qq_31076523/article/details/134176793。百度和各类采集站皆不可信,搜索请谨慎鉴别。技术类文章一般都有时效性,本人习惯不定期对自己的博文进行修正和更新,因此请访问出处以查看本文的最新版本。

相关推荐
你怎么知道我是队长6 小时前
C语言---头文件
c语言·开发语言
期待のcode6 小时前
Java虚拟机的运行模式
java·开发语言·jvm
hqwest6 小时前
码上通QT实战25--报警页面01-报警布局设计
开发语言·qt·qwidget·ui设计·qt布局控件
a程序小傲6 小时前
京东Java面试被问:动态规划的状态压缩和优化技巧
java·开发语言·mysql·算法·adb·postgresql·深度优先
HellowAmy6 小时前
我的C++规范 - 玩一个小游戏
开发语言·c++·代码规范
徐先生 @_@|||7 小时前
Palantir Foundry 五层架构模型详解
开发语言·python·深度学习·算法·机器学习·架构
tang777898 小时前
爬虫如何绕过绕过“5秒盾”Cloudflare:从浏览器指纹模拟到Rust求解之不完全指南
开发语言·爬虫·rust·cloudflare
Yuer20258 小时前
什么是 Rust 语境下的“量化算子”——一个工程对象的最小定义
开发语言·后端·rust·edca os·可控ai
hqwest8 小时前
码上通QT实战26--系统设置01-系统设置布局
开发语言·qt·qss·qt基础控件·qt布局控件·qt表格控件
薛定谔的猫19828 小时前
llama-index Embedding 落地到 RAG 系统
开发语言·人工智能·python·llama-index