关注
第三题我完全参考了檐之同学的思路,可以把算法复杂度从O(n2)降到O(n)。附上原作者的链接:https://www.nowcoder.com/discuss/226305?type=post&order=time&pos=&page=1 申请两个数组,lookBackward[i]表示向坐标递减的方向看时,在i位置能看到的楼的个数;lookForward[i]表示向坐标递增的方向看时,在i位置能看到的楼的个数。用栈的size记录楼的个数,若栈顶楼高小于等于当前遍历到的楼高则pop栈顶,否则直接push新楼。 很巧妙的地方是,计算lookBackward数组时从前往后遍历,计算lookForward数组时从后向前遍历,这样刚刚分析的逻辑才成立。最后记得算上当前楼,输出+1。代码如下: import java.util.Scanner;
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int[] nums = new int[n];
for (int i = 0; i < n; i++) {
nums[i] = sc.nextInt();
}
int[] lookBackward = new int[n];
int[] lookForward = new int[n];
int[] results = new int[n];
Deque<Integer> stack = new ArrayDeque<>();
stack.push(nums[0]);
for(int i = 1; i < n; i++){
lookBackward[i] = stack.size();
if(!stack.isEmpty() && nums[i] >= stack.peek()){
stack.pop();
}
stack.push(nums[i]);
}
stack.clear();
stack.push(nums[n-1]);
for(int i = n-2; i >= 0; i--){
lookForward[i] = stack.size();
if(!stack.isEmpty() && nums[i] >= stack.peek()){
stack.pop();
}
stack.push(nums[i]);
}
for(int i=0; i < n; i++){
results[i] = lookBackward[i] + lookForward[i] + 1;
System.out.print(results[i] + " ");
}
}
}
查看原帖
点赞 3
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
10-24 19:59
门头沟学院 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 找工作能把i人逼成什么样 #
14190次浏览 173人参与
# 上班到公司第一件事做什么? #
108974次浏览 732人参与
# 你今年做了几份实习? #
9417次浏览 144人参与
# 工作两年想退休了 #
202972次浏览 1791人参与
# 你开始找寒假实习了吗? #
15508次浏览 209人参与
# 新凯来求职进展汇总 #
64047次浏览 171人参与
# 影石Insta360求职进展汇总 #
166419次浏览 1335人参与
# 大厂面试初体验 #
83444次浏览 384人参与
# 0经验如何找实习? #
26580次浏览 451人参与
# 面试尴尬现场 #
204984次浏览 820人参与
# 大学最后一个寒假,我想…… #
72071次浏览 725人参与
# 25届秋招公司红黑榜 #
306552次浏览 1252人参与
# 什么样的公司千万别去 #
27848次浏览 146人参与
# 大家每天通勤多久? #
64347次浏览 414人参与
# 金融财经春招备战日记 #
43832次浏览 216人参与
# 央国企投递记录 #
165975次浏览 1622人参与
# 你找工作经历过哪些骗局? #
9472次浏览 143人参与
# 机械人值得去的半导体企业 #
32954次浏览 183人参与
# 字节出了豆包coding模型 #
6834次浏览 61人参与
# 一起聊华为 #
168356次浏览 820人参与