Add 2021-01 Golang and benchmark
Signed-off-by: AKU <tom@tdpain.net>
This commit is contained in:
parent
6e8a4c7364
commit
3242e53adc
2 changed files with 85 additions and 0 deletions
23
challenges/2021/01-sonarSweep/benchmark.txt
Normal file
23
challenges/2021/01-sonarSweep/benchmark.txt
Normal file
|
@ -0,0 +1,23 @@
|
|||
Day 1 (Sonar Sweep) benchmark
|
||||
|
||||
Dir: challenges/2021/01-sonarSweep
|
||||
Runs per part: 200
|
||||
--------------------------------------------------------------------------------
|
||||
Golang
|
||||
|
||||
benchmark.part.1.avg: 0.000094 seconds
|
||||
benchmark.part.1.min: 0.000047 seconds
|
||||
benchmark.part.1.max: 0.000818 seconds
|
||||
benchmark.part.2.avg: 0.000112 seconds
|
||||
benchmark.part.2.min: 0.000057 seconds
|
||||
benchmark.part.2.max: 0.000535 seconds
|
||||
--------------------------------------------------------------------------------
|
||||
Python
|
||||
|
||||
benchmark.part.1.avg: 0.001437 seconds
|
||||
benchmark.part.1.min: 0.000452 seconds
|
||||
benchmark.part.1.max: 0.012373 seconds
|
||||
benchmark.part.2.avg: 0.002187 seconds
|
||||
benchmark.part.2.min: 0.000762 seconds
|
||||
benchmark.part.2.max: 0.005535 seconds
|
||||
--------------------------------------------------------------------------------
|
62
challenges/2021/01-sonarSweep/go/challenge.go
Normal file
62
challenges/2021/01-sonarSweep/go/challenge.go
Normal file
|
@ -0,0 +1,62 @@
|
|||
package challenge
|
||||
|
||||
import (
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
"github.com/codemicro/adventOfCode/lib/aocgo"
|
||||
)
|
||||
|
||||
func parse(instr string) ([]int, error) {
|
||||
var o []int
|
||||
for _, line := range strings.Split(instr, "\n") {
|
||||
if line == "" {
|
||||
continue
|
||||
}
|
||||
t := strings.TrimSpace(line)
|
||||
n, err := strconv.Atoi(t)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
o = append(o, n)
|
||||
}
|
||||
return o, nil
|
||||
}
|
||||
|
||||
func countIncreases(data []int) int {
|
||||
var c int
|
||||
for i := 1; i < len(data); i += 1 {
|
||||
if data[i] > data[i-1] {
|
||||
c += 1
|
||||
}
|
||||
}
|
||||
return c
|
||||
}
|
||||
|
||||
type Challenge struct {
|
||||
aocgo.BaseChallenge
|
||||
}
|
||||
|
||||
func (c Challenge) One(instr string) (interface{}, error) {
|
||||
data, err := parse(instr)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return countIncreases(data), nil
|
||||
}
|
||||
|
||||
func (c Challenge) Two(instr string) (interface{}, error) {
|
||||
data, err := parse(instr)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var sums []int
|
||||
{
|
||||
for i := 0; i < len(data)-2; i += 1 {
|
||||
sums = append(sums, data[i]+data[i+1]+data[i+2])
|
||||
}
|
||||
}
|
||||
|
||||
return countIncreases(sums), nil
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue