关注
第三题我完全参考了檐之同学的思路,可以把算法复杂度从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
相关推荐

点赞 评论 收藏
分享
点赞 评论 收藏
分享
09-06 12:49
东北大学 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 大厂VS公务员你怎么选 #
36961次浏览 480人参与
# 腾讯工作体验 #
515347次浏览 3551人参与
# 平安产险科技校招 #
1363次浏览 0人参与
# 发面经攒人品 #
2638594次浏览 35972人参与
# 你现在会用到哪些AI技能? #
11127次浏览 100人参与
# 我的求职进度条 #
109002次浏览 1350人参与
# 智慧芽求职进展汇总 #
2573次浏览 5人参与
# 我对___祛魅了 #
133389次浏览 740人参与
# 多益网络工作体验 #
55748次浏览 292人参与
# 你还有多少年退休? #
27539次浏览 192人参与
# 来聊聊机械薪资天花板是哪家 #
145561次浏览 801人参与
# 工作中的卑微时刻 #
25661次浏览 175人参与
# 你有哪些缓解焦虑的方法? #
35781次浏览 828人参与
# 小马智行求职进展汇总 #
14289次浏览 50人参与
# 机械人与华为的爱恨情仇 #
133237次浏览 1008人参与
# 实习在多还是在精 #
38216次浏览 267人参与
# 你觉得材料多少算高薪 #
26856次浏览 159人参与
# 顺丰求职进展汇总 #
64257次浏览 316人参与
# 你的房租占工资的比例是多少? #
66142次浏览 803人参与
# 秋招踩过的“雷”,希望你别再踩 #
90975次浏览 1127人参与
# 实习下班不想学习,正常吗? #
23556次浏览 189人参与
# 反问环节如何提问 #
116346次浏览 2477人参与