山脉的个数/攀登者

题目描述

攀登者喜欢寻找各种地图,并且尝试攀登到最高的山峰。

地图表示为一维数组,数组的索引代表水平位置,数组的元素代表相对海拔高度。其中数组元素0代表地面。

例如:[0,1,2,4,3,1,0,0,1,2,3,1,2,1,0],代表如下图所示的地图,地图中有两个山脉位置分别为 1,2,3,4,5 和 8,9,10,11,12,13,最高峰高度分别为 4,3。最高峰位置分别为3,10。

一个山脉可能有多座山峰(高度大于相邻位置的高度,或在地图边界且高度大于相邻的高度)。
登山者想要知道一张地图中有多少座山峰。
image-20231109223048368

输入描述

输入为一个整型数组,数组长度大于1。

输出描述

输出地图中山峰的数量。

用例1

输入

0, 1, 2, 3, 2, 4

输出

2

说明:

元素3和4 都是山峰,输出2.
image-20231109223048368

用例2

输入

0,1,4,3,1,0,0,1,2,3,1,2,1,0

输出

3

说明 山峰所在索引分别为3,10,12

代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_LEN 100
int func(int num[], int n) {
   
    int cnt = 0;
    for (int i = 0; i < n; i++) {
   
        if (i == 0 && num[i] > num[i + 1]) {
   
            cnt++;
        } else if (i == n - 1 && num[i] > num[i - 1]) {
   
            cnt++;
        } else if (i > 0 && i < n - 1 && num[i] > num[i - 1] &&
                   num[i] > num[i + 1]) {
   
            cnt++;
        }
    }
    return cnt;
}

int main() {
   
    char line[MAX_LEN + 1];
    fgets(line, MAX_LEN + 1, stdin);
    line[strcspn(line, "\n")] = '\0';
    int num[MAX_LEN];
    char *token = strtok(line, ",");
    int i = 0;
    while (token != NULL) {
   
        num[i++] = atoi(token);
        token = strtok(NULL, ",");
    }
    int res = func(num, i);
    printf("%d", res);
    return 0;
}

相关推荐

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

    2024-02-15 17:36:02       32 阅读
  2. 华为机考真题 -- 攀登1

    2024-02-15 17:36:02       27 阅读
  3. 941. 有效山脉数组

    2024-02-15 17:36:02       41 阅读
  4. 华为OD机试真题-攀登1-2023年OD统一考试(C卷)

    2024-02-15 17:36:02       75 阅读
  5. 华为OD机试真题- 攀登2-2024年OD统一考试(C卷)

    2024-02-15 17:36:02       49 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-15 17:36:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-15 17:36:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-15 17:36:02       87 阅读
  4. Python语言-面向对象

    2024-02-15 17:36:02       96 阅读

热门阅读

  1. 2月12作业

    2024-02-15 17:36:02       46 阅读
  2. hpp文件:C++开发中的利器

    2024-02-15 17:36:02       45 阅读
  3. 【zabbix】(四)-钉钉告警&企业微信配置

    2024-02-15 17:36:02       79 阅读
  4. Rust的if let语法:更简洁的模式匹配

    2024-02-15 17:36:02       45 阅读
  5. 【ASP.NET 6 Web Api 全栈开发实战】--前言

    2024-02-15 17:36:02       50 阅读
  6. 作业2024/2/15

    2024-02-15 17:36:02       43 阅读
  7. D. Yet Another Sorting Problem - 树状数组求逆序数

    2024-02-15 17:36:02       50 阅读