博客
关于我
【Lintcode】1416. The Previous Number
阅读量:215 次
发布时间:2019-02-28

本文共 1135 字,大约阅读时间需要 3 分钟。

题目地址:

给定一个数组 A A A,要求返回一个数组 B B B使得 B [ i ] B[i] B[i] A [ i ] A[i] A[i]左边第一个小于 A [ i ] A[i] A[i]的数。如果不存在则令 B [ i ] = A [ i ] B[i]=A[i] B[i]=A[i]

思路是单调栈。维护一个严格单调递增的栈,然后遍历 A A A。当遍历到 A [ i ] A[i] A[i]时,如果栈空或者栈顶大于等于 A [ i ] A[i] A[i],就pop栈顶,直到栈顶小于 A [ i ] A[i] A[i]为止。接着,如果栈不空,则 A [ i ] A[i] A[i]左边第一个小于它的数就是栈顶,如果栈空的话,则说明不存在。代码如下:

import java.util.ArrayDeque;import java.util.Deque;public class Solution {       /**     * @param num: The arry you should handle     * @return: Return the array     */    public int[] getPreviousNumber(int[] num) {           // Write your code here        int[] res = new int[num.length];                Deque
stack = new ArrayDeque<>(); for (int i = 0; i < num.length; i++) { // 保持从栈底到栈顶的严格单调上升性 while (!stack.isEmpty() && stack.peek() >= num[i]) { stack.pop(); } if (!stack.isEmpty()) { res[i] = stack.peek(); } else { res[i] = num[i]; } stack.push(num[i]); } return res; }}

时空复杂度 O ( l A ) O(l_A) O(lA)

转载地址:http://slcs.baihongyu.com/

你可能感兴趣的文章
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
Mysql 整形列的字节与存储范围
查看>>
MySQL 日期时间类型的选择
查看>>
MySQL 是如何加锁的?
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>