修改 0084.柱状图中最大的矩形 Go单调栈代码的格式

This commit is contained in:
ShuangmingMa
2023-09-16 22:33:02 +08:00
committed by GitHub
parent 8c3f064927
commit c26fddc702

View File

@ -478,7 +478,6 @@ class Solution:
```go ```go
func largestRectangleArea(heights []int) int { func largestRectangleArea(heights []int) int {
// 声明max并初始化为0
max := 0 max := 0
// 使用切片实现栈 // 使用切片实现栈
stack := make([]int, 0) stack := make([]int, 0)
@ -488,15 +487,15 @@ func largestRectangleArea(heights []int) int {
heights = append(heights, 0) heights = append(heights, 0)
// 初始化栈序号从0开始 // 初始化栈序号从0开始
stack = append(stack, 0) stack = append(stack, 0)
for i := 1; i < len(heights); i++ { for i := 1; i < len(heights); i ++ {
// 结束循环条件为:当即将入栈元素>top元素也就是形成非单调递增的趋势 // 结束循环条件为:当即将入栈元素>top元素也就是形成非单调递增的趋势
for heights[stack[len(stack)-1]] > heights[i] { for heights[stack[len(stack) - 1]] > heights[i] {
// mid 是top // mid 是top
mid := stack[len(stack)-1] mid := stack[len(stack) - 1]
// 出栈 // 出栈
stack = stack[0 : len(stack)-1] stack = stack[0 : len(stack) - 1]
// left是top的下一位元素i是将要入栈的元素 // left是top的下一位元素i是将要入栈的元素
left := stack[len(stack)-1] left := stack[len(stack) - 1]
// 高度x宽度 // 高度x宽度
tmp := heights[mid] * (i - left - 1) tmp := heights[mid] * (i - left - 1)
if tmp > max { if tmp > max {
@ -507,7 +506,6 @@ func largestRectangleArea(heights []int) int {
} }
return max return max
} }
``` ```
### JavaScript: ### JavaScript: