feat: monday
This commit is contained in:
31
pkg/trapping_rain_water/main.go
Normal file
31
pkg/trapping_rain_water/main.go
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
package trapping_rain_water
|
||||||
|
|
||||||
|
func Trap(heights []int) int {
|
||||||
|
// Calculate area taken up by the boundary.
|
||||||
|
boundary_area := 0
|
||||||
|
for _, height := range heights {
|
||||||
|
boundary_area += height
|
||||||
|
}
|
||||||
|
|
||||||
|
// Calculate the total area taken up by the boundary and the water.
|
||||||
|
total_area := 0
|
||||||
|
left := 0
|
||||||
|
left_height := 0
|
||||||
|
right := len(heights) - 1
|
||||||
|
right_height := 0
|
||||||
|
|
||||||
|
for left <= right {
|
||||||
|
left_height = max(left_height, heights[left])
|
||||||
|
right_height = max(right_height, heights[right])
|
||||||
|
|
||||||
|
if left_height < right_height {
|
||||||
|
total_area += left_height
|
||||||
|
left++
|
||||||
|
} else {
|
||||||
|
total_area += right_height
|
||||||
|
right--
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return total_area - boundary_area
|
||||||
|
}
|
||||||
31
pkg/trapping_rain_water/main_test.go
Normal file
31
pkg/trapping_rain_water/main_test.go
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
package trapping_rain_water
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestTrap_Example1(t *testing.T) {
|
||||||
|
height := []int{0, 1, 0, 2, 1, 0, 1, 3, 2, 1, 2, 1}
|
||||||
|
expected := 6
|
||||||
|
result := Trap(height)
|
||||||
|
|
||||||
|
assert.Equal(t, expected, result)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestTrap_Example2(t *testing.T) {
|
||||||
|
height := []int{4, 2, 0, 3, 2, 5}
|
||||||
|
expected := 9
|
||||||
|
result := Trap(height)
|
||||||
|
|
||||||
|
assert.Equal(t, expected, result)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestTrap_Example3(t *testing.T) {
|
||||||
|
height := []int{0}
|
||||||
|
expected := 0
|
||||||
|
result := Trap(height)
|
||||||
|
|
||||||
|
assert.Equal(t, expected, result)
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user