华为OD机试之阿里巴巴找黄金宝箱(IV) C++

题目背景

贫如洗的椎夫阿里巴巴在去砍柴的路上,无意中发现了强盗集团的藏宝地,藏宝地有编号从0-N的箱子,每个箱子上面有一人数字,箱子排列成一个环,编号最大的箱子的下一个是编号为0的箱子。请输出每个箱了贴的数字之后的第一个比它大的数,如果不存在则输出-1。

输入描述

输入一个数字字串,数字之间使用逗号分隔,例如: 1,2,3,1
1≤ 字串中数字个数 ≤10000:
-100000≤每个数字值≤100000

输出描述

下一个大的数列表,以逗号分隔,例如: 2,3,6,-1,6

示例1:

输入:2,5,2

输出:5,-1,5

说明:第一个2的下一个更大的数是5数字5找不到下一个更大的数:第二个2的下一个最大的数需要循环搜索,结果也是 5

示例2:

输入:3,4,5,6,3

输出:4,5,6,-1,4

解题思路

这个问题是一个经典的“下一个更大元素”问题,可以使用单调栈来解决。以下是解题思路:

  1. 理解问题:我们需要找到每个元素后面的第一个比它大的元素。如果不存在这样的元素,就返回-1。因为箱子是环形排列的,所以如果没有在当前元素后面找到更大的元素,我们需要回到数组的开始继续查找。

  2. 选择数据结构:我们选择使用栈来解决这个问题,因为栈可以帮助我们快速找到前面的元素,并且可以在O(1)的时间内插入和删除元素。

  3. 算法设计:我们遍历数组两次,模拟环形数组。对于每个元素,我们将其索引压入栈中。然后,我们检查栈顶元素是否小于当前元素。如果是,那么我们就找到了栈顶元素后面的第一个更大的元素,我们更新结果数组,并将栈顶元素弹出。我们重复这个过程,直到栈为空或者栈顶元素大于当前元素。然后,我们将当前元素的索引压入栈中。

  4. 处理边界情况:如果我们遍历完整个数组,栈中仍然有元素,这些元素后面没有更大的元素,所以我们将结果数组中对应的位置设为-1。

  5. 复杂度分析:这个算法的时间复杂度和空间复杂度都是O(N),其中N是输入数组的长度。这是因为我们需要遍历数组两次,并且在堆栈中最多存储N个元素。

希望这个解题思路对你有所帮助!

解决方案

#include <vector>  // 引入向量库,用于存储输入的数字和结果
#include <stack>   // 引入栈库,用于实现单调栈
#include <iostream> // 引入输入输出流库,用于读取输入和打印输出
#include <sstream>  // 引入字符串流库,用于处理字符串

// 定义函数nextGreaterElements,输入是一个整数向量,输出也是一个整数向量
std::vector<int> nextGreaterElements(std::vector<int>& nums) {
    int n = nums.size();  // 获取输入向量的大小
    std::vector<int> res(n, -1);  // 初始化结果向量,大小与输入向量相同,所有元素初始值为-1
    std::stack<int> s;  // 初始化一个空栈,用于存储元素的索引
    // 遍历输入向量两次,模拟环形数组
    for (int i = 0; i < 2 * n; i++) {
        // 当栈非空且当前元素大于栈顶元素时,更新栈顶元素的结果为当前元素,并弹出栈顶元素
        while (!s.empty() && nums[s.top()] < nums[i % n]) {
            res[s.top()] = nums[i % n];
            s.pop();
        }
        // 将当前元素的索引压入栈中
        s.push(i % n);
    }
    // 返回结果向量
    return res;
}

// 主函数
int main() {
    std::string line;  // 定义一个字符串,用于存储输入的一行
    std::getline(std::cin, line);  // 从标准输入读取一行
    std::istringstream iss(line);  // 创建一个字符串流,用于处理字符串
    std::vector<int> nums;  // 定义一个整数向量,用于存储输入的数字
    // 使用逗号作为分隔符,将字符串分割为多个数字,并存入向量中
    for (std::string s; std::getline(iss, s, ','); ) {
        nums.push_back(std::stoi(s));
    }
    // 调用nextGreaterElements函数,获取结果
    std::vector<int> res = nextGreaterElements(nums);
    // 打印结果
    for (int i = 0; i < res.size(); i++) {
        if (i > 0) std::cout << ",";
        std::cout << res[i];
    }
    return 0;  // 程序正常结束,返回0
}

测试用例


两次测试全部通过。

方案总结

这个解决方案的时间复杂度是O(N),空间复杂度也是O(N),其中N是输入数组的长度。这是因为我们需要遍历数组两次(模拟环形数组),并且在堆栈中最多存储N个元素。这个解决方案应该能够处理最大10000个元素的输入。请注意,这个解决方案假设输入的数字都是整数。如果输入的数字可能是浮点数,那么你需要稍微修改一下代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/343477.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【记一次线上事故的排查思路】- CPU飙升问题排查

问题描述 由于项目排期较紧&#xff0c;临时从其他组调来三个开发资源帮我一起做项目&#xff0c;难免上线的时候大家的需求一块上线。 问题来了&#xff0c;上线三天后&#xff0c;线上CPU总是莫名奇妙的突然飙升&#xff0c;飙升后CPU并未降下来&#xff0c;而是一直处在高点…

解密POM:提升自动化脚本稳定性和开发效率的正确姿势!

Page Objects是selenium的一种测试设计模式&#xff0c;主要将每个页面看作是一个class。class的内容主要包括属性和方法&#xff0c;属性不难理解&#xff0c;就是这个页面中的元素对象&#xff0c;比如输入用户名的输入框&#xff0c;输入登陆密码的输入框、登陆按钮、这个页…

《WebKit 技术内幕》学习之七(3): 渲染基础

3 渲染方式 3.1 绘图上下文&#xff08;GraphicsContext&#xff09; 上面介绍了WebKit的内部表示结构&#xff0c;RenderObject对象知道如何绘制自己&#xff0c;但是&#xff0c;问题是RenderObject对象用什么来绘制内容呢&#xff1f;在WebKit中&#xff0c;绘图操作被定…

【Leetcode】2765. 最长交替子数组

文章目录 题目思路代码结果 题目 2765. 最长交替子数组 题目&#xff1a;给你一个下标从 0 开始的整数数组 nums 。如果 nums 中长度为 m 的子数组 s 满足以下条件&#xff0c;我们称它是一个 交替子数组 &#xff1a; m 大于 1 。 s1 s0 1 。 下标从 0 开始的子数组 s 与…

Vue中$watch()方法和watch属性的区别

vue中$watch()和watch属性都是监听值的变化的&#xff0c;是同一个作用&#xff0c;但是有两个不同写法。 用法一&#xff1a; //注意&#xff1a;这种方法是监听不到对象的变化的。 this.$watch((newVal,oldVal)>{ }) 用法二&#xff1a; watch:{xxx:(newVal,oldVal)>…

SpringCloud Aliba-Seata【上】-从入门到学废【7】

目录 &#x1f9c2;.Seata是什么 &#x1f32d;2.Seata术语表 &#x1f953;3.处理过程 &#x1f9c8;4.下载 &#x1f37f;5.修改相关配置 &#x1f95e;6.启动seata 1.Seata是什么 Seata是一款开源的分布式事务解决方案&#xff0c;致力于在微服务架构下提供高性能…

硅像素传感器文献调研(八)

1977 平面单场限环器件的理论与击穿电压 摘要 使用一个或多个浮置场限制环减少了平面器件中结曲率对击穿电压的不利影响。虽然这已经知道了一段时间&#xff0c;但还没有一种方法可以准确地预测使用场环可以实现的改善量。本文提出了一种计算机算法&#xff0c;它使得有可能进…

残差连接是什么意思

残差连接是深度神经网络中一种用于缓解梯度消失问题的技术。它的核心思想是通过将网络的输入直接传递到网络的输出&#xff0c;从而构建了一条直达路径&#xff0c;使得梯度更容易通过整个网络传播。这有助于在训练深层网络时避免梯度消失或梯度爆炸的问题。 在残差连接中&…

Linux 一键部署grafana

grafana 前言 Grafana 是一款开源的数据可视化和监控仪表盘工具。它提供了丰富的数据查询、可视化和报警功能,可用于实时监控、数据分析和故障排除等领域。 通过 Grafana,您可以连接到各种不同的数据源,包括时序数据库(如 Prometheus、InfluxDB)和关系型数据库(如 MySQ…

题记(26)--Sharing(链表公共后缀)

目录 一、题目内容 二、输入描述 三、输出描述 四、输入输出示例 五、完整C语言代码 一、题目内容 To store English words, one method is to use linked lists and store a word letter by letter. To save some space, we may let the words share the same sublist if…

Mybatis----缓存

MyBatis是一个流行的Java持久化框架&#xff0c;它提供了一个灵活的缓存机制来提高查询性能。 MyBatis的缓存机制主要分为一级缓存和二级缓存。 一级缓存是指在同一个SqlSession中&#xff0c;查询结果会被缓存起来&#xff0c;当再次执行同样的查询时&#xff0c;直接从缓存中…

Python学习04—基本图形绘制

通过一个案例来初步认识Python的图形绘制 案例&#xff1a;绘制Python蟒蛇 #PythonDraw.py import turtle turtle.setup(650,350,200,200) turtle.penup() turtle.fd(-250) turtle.pendown() turtle.pensize(25) turtle.pencolor("purple") turtle.seth(-40) for i…

基于springboot+vue的“衣依”服装销售平台系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 研究背景…

使用云服务器被攻击,该如何防止ddos攻击

目前我们运行各项网络业务都离不开服务器&#xff0c;现在使用比较多的都是云服务器了。大家都知道&#xff0c;目前市场上用的云服务器大多数都是没有带什么防护了&#xff0c;那么用云服务器的时候&#xff0c;如果遭受到了ddos攻击&#xff0c;该怎么办&#xff0c;云服务器…

司铭宇老师:家具导购销售培训:家具导购员销售技巧和话术

家具导购销售培训&#xff1a;家具导购员销售技巧和话术 在现代家居市场中&#xff0c;家具不仅仅是日常生活的必需品&#xff0c;更是体现居住者个性和生活品味的重要元素。作为家具导购员&#xff0c;掌握专业的销售技巧和巧妙的话术对于吸引顾客、提高成交率至关重要。本文将…

[每日一题] 01.23 - 画矩形

画矩形 height,width,c,d input().split() height,width,d int(height),int(width),int(d) lis [c * width if d else c * (width - 2) c for i in range(height) ]lis: ##### # # # # ##### 或 # # # # # # # #if not d:print(c * width)for i in lis[1:-1…

【Linux编辑器-vim使用】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言 一、vim的基本概念 二、vim的基本操作 分屏操作&#xff1a; 三、vim正常&#xff08;命令&#xff09;模式命令集 四、vim末行&#xff08;底行&#xff09;模…

PHP+vue+Mysql家庭理财管理系统演5x6nf

本文着重阐述了收支管理系统的分析、设计与实现&#xff0c;首先介绍开发系统和环境配置、数据库的设计&#xff0c;对系统的功能需求作出分析&#xff0c;根据需求对系统进行设计&#xff0c;明确各个部分的规范&#xff0c;来完成系统的设计。最后在对设计的系统进行一系列的…

项目工程下载与XML配置文件下载:EtherCAT超高速实时运动控制卡XPCIE1032H上位机C#开发(十)

XPCIE1032H功能简介 XPCIE1032H是一款基于PCI Express的EtherCAT总线运动控制卡&#xff0c;可选6-64轴运动控制&#xff0c;支持多路高速数字输入输出&#xff0c;可轻松实现多轴同步控制和高速数据传输。 XPCIE1032H集成了强大的运动控制功能&#xff0c;结合MotionRT7运动…

Mysql学习笔记系列(一)

本次mysql系列不会讲解具体的查询语句&#xff0c;而是放在mysql的一些性能优化和一些特性上&#xff0c;是学习笔记&#xff0c;供大家参考补充。 慢查询 MySQL的慢查询&#xff0c;全名是慢查询日志&#xff0c;是MySQL提供的一种日志记录&#xff0c;用来记录在MySQL中响应…