当前位置: 首页 > news >正文

山脉的个数/攀登者

题目描述

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

地图表示为一维数组,数组的索引代表水平位置,数组的元素代表相对海拔高度。其中数组元素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;
}

相关文章:

  • 二叉树-------前,中,后序遍历 + 前,中,后序查找+删除节点 (java详解)
  • Stream流学习笔记
  • openJudge | 过滤多余的空格 C语言
  • Leetcode29:两数相除
  • 【python之美】减少人工成本之批量拿取文件名保存_4
  • Rust的Match语句:强大的控制流运算符
  • Gin 中使用 base64Captcha 生成图形验证码
  • flask+python高校学生综合测评管理系统 phl8b
  • 1.JavaScript中的数据类型
  • 小白学习Halcon100例:如何利用动态阈值分割图像进行PCB印刷缺陷检测?
  • DolphinScheduler安装与配置
  • 《零基础实践深度学习》波士顿房价预测任务1.3.3.4训练过程
  • 寒假学习记录13:JS对象
  • 探索XGBoost:自动化机器学习(AutoML)
  • 投资银行在网络安全生态中的作用
  • 【跃迁之路】【669天】程序员高效学习方法论探索系列(实验阶段426-2018.12.13)...
  • 07.Android之多媒体问题
  • Angular 响应式表单 基础例子
  • Angular 响应式表单之下拉框
  • Angular6错误 Service: No provider for Renderer2
  • CentOS从零开始部署Nodejs项目
  • Codepen 每日精选(2018-3-25)
  • Docker 笔记(2):Dockerfile
  • echarts花样作死的坑
  • IIS 10 PHP CGI 设置 PHP_INI_SCAN_DIR
  • JavaWeb(学习笔记二)
  • markdown编辑器简评
  • springboot_database项目介绍
  • vue 配置sass、scss全局变量
  • 百度贴吧爬虫node+vue baidu_tieba_crawler
  • 搭建gitbook 和 访问权限认证
  • 爬虫模拟登陆 SegmentFault
  • 前言-如何学习区块链
  • 手写一个CommonJS打包工具(一)
  • 算法-插入排序
  • 我与Jetbrains的这些年
  • 要让cordova项目适配iphoneX + ios11.4,总共要几步?三步
  • No resource identifier found for attribute,RxJava之zip操作符
  • Java总结 - String - 这篇请使劲喷我
  • k8s使用glusterfs实现动态持久化存储
  • PostgreSQL 快速给指定表每个字段创建索引 - 1
  • ​直流电和交流电有什么区别为什么这个时候又要变成直流电呢?交流转换到直流(整流器)直流变交流(逆变器)​
  • (LeetCode 49)Anagrams
  • (zt)基于Facebook和Flash平台的应用架构解析
  • (分享)一个图片添加水印的小demo的页面,可自定义样式
  • (介绍与使用)物联网NodeMCUESP8266(ESP-12F)连接新版onenet mqtt协议实现上传数据(温湿度)和下发指令(控制LED灯)
  • (十二)springboot实战——SSE服务推送事件案例实现
  • (一)appium-desktop定位元素原理
  • (一)Java算法:二分查找
  • (转)甲方乙方——赵民谈找工作
  • (轉貼) 資訊相關科系畢業的學生,未來會是什麼樣子?(Misc)
  • (轉貼)《OOD启思录》:61条面向对象设计的经验原则 (OO)
  • . ./ bash dash source 这五种执行shell脚本方式 区别
  • .NET CLR基本术语
  • .NET Core IdentityServer4实战-开篇介绍与规划