feat: saturday

This commit is contained in:
2025-12-14 12:40:54 -05:00
parent 22a39df9f9
commit 2a6e1677d6
7 changed files with 164 additions and 0 deletions

49
pkg/two_sum/main.go Normal file
View File

@@ -0,0 +1,49 @@
package two_sum
import (
"slices"
)
type Index struct {
Index int
Value int
}
func ByValue(a, b Index) int {
return a.Value - b.Value
}
func ToIndices(list []int) []Index {
result := []Index{}
for index, value := range list {
result = append(result, Index{index, value})
}
slices.SortFunc(result, ByValue)
return result
}
// https://leetcode.com/problems/two-sum/description/
func TwoSum(nums []int, target int) []int {
numbers := ToIndices(nums)
lower, upper := 0, len(numbers)-1
for lower < upper {
current_sum := numbers[lower].Value + numbers[upper].Value
if current_sum < target {
lower++
} else if current_sum > target {
upper--
} else {
return []int{
numbers[lower].Index,
numbers[upper].Index,
}
}
}
return nil
}

14
pkg/two_sum/main_test.go Normal file
View File

@@ -0,0 +1,14 @@
package two_sum_test
import (
"testing"
"git.maximhutz.com/practice/pkg/two_sum"
"github.com/stretchr/testify/assert"
)
func TestTwoSum(t *testing.T) {
assert.Equal(t, two_sum.TwoSum([]int{2, 7, 11, 15}, 9), []int{0, 1})
assert.Equal(t, two_sum.TwoSum([]int{3, 2, 4}, 6), []int{1, 2})
assert.Equal(t, two_sum.TwoSum([]int{3, 3}, 6), []int{0, 1})
}

View File

@@ -0,0 +1,47 @@
package wildcard_matching
var Cache = map[[2]string]bool{}
func MatchesCached(letters, pattern string) bool {
key := [2]string{letters, pattern}
if matches, exists := Cache[key]; exists {
return matches
}
result := Matches(letters, pattern)
Cache[key] = result
return result
}
func RemoveLeadingWildcards(pattern string) string {
for i := 0; i < len(pattern); i++ {
if pattern[i] != '*' {
return pattern[i:]
}
}
return ""
}
func Matches(letters string, pattern string) bool {
if len(letters) == 0 && len(pattern) == 0 {
return true
}
if len(pattern) != 0 && pattern[0] == '*' {
for i := 0; i <= len(letters); i++ {
if MatchesCached(letters[i:], RemoveLeadingWildcards(pattern)) {
return true
}
}
return false
}
if len(pattern) != 0 && len(letters) != 0 && (pattern[0] == '?' || pattern[0] == letters[0]) {
return MatchesCached(letters[1:], pattern[1:])
}
return false
}

View File

@@ -0,0 +1,32 @@
package wildcard_matching_test
import (
"testing"
"git.maximhutz.com/practice/pkg/wildcard_matching"
"github.com/stretchr/testify/assert"
)
func TestTwoSum1(t *testing.T) {
assert.Equal(t, false, wildcard_matching.Matches("aa", "a"))
}
func TestTwoSum2(t *testing.T) {
assert.Equal(t, true, wildcard_matching.Matches("aa", "*"))
}
func TestTwoSum3(t *testing.T) {
assert.Equal(t, false, wildcard_matching.Matches("cb", "?a"))
}
func TestTwoSum4(t *testing.T) {
assert.Equal(t, true, wildcard_matching.Matches("banana", "**********"))
}
func TestTwoSum5(t *testing.T) {
assert.Equal(t, true, wildcard_matching.Matches("", "******"))
}
func TestTwoSum6(t *testing.T) {
assert.Equal(t, false, wildcard_matching.Matches("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaab", "*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************a"))
}