Sha256: f500f10c81434e3843e07fbdd76d626c3cea3bb7114aa739be3cf748484208bc

Contents?: true

Size: 1.62 KB

Versions: 158

Compression:

Stored size: 1.62 KB

Contents

package pythagorean

// Use this type definition,
//
//    type Triplet [3]int
//
// and implement two functions,
//
//    Range(min, max int) []Triplet
//    Sum(p int) []Triplet
//
// Range returns a list of all Pythagorean triplets with sides in the
// range min to max inclusive.
//
// Sum returns a list of all Pythagorean triplets where the sum a+b+c
// (the perimeter) is equal to p.
//
// The three elements of each returned triplet must be in order,
// t[0] <= t[1] <= t[2], and the list of triplets must be in lexicographic
// order.

import (
	"reflect"
	"testing"
)

const targetTestVersion = 1

func TestTestVersion(t *testing.T) {
	if testVersion != targetTestVersion {
		t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
	}
}

var rangeTests = []struct {
	min, max int
	ts       []Triplet
}{
	{1, 10, []Triplet{{3, 4, 5}, {6, 8, 10}}},
	{11, 20, []Triplet{{12, 16, 20}}},
}

func TestRange(t *testing.T) {
	for _, test := range rangeTests {
		ts := Range(test.min, test.max)
		if !reflect.DeepEqual(ts, test.ts) {
			t.Fatalf("Range(%d, %d) = %v, want %v",
				test.min, test.max, ts, test.ts)
		}
	}
}

var sumTests = []struct {
	sum int
	ts  []Triplet
}{
	{180, []Triplet{{18, 80, 82}, {30, 72, 78}, {45, 60, 75}}},
	{1000, []Triplet{{200, 375, 425}}},
}

func TestSum(t *testing.T) {
	for _, test := range sumTests {
		ts := Sum(test.sum)
		if !reflect.DeepEqual(ts, test.ts) {
			t.Fatalf("Sum(%d) = %v, want %v",
				test.sum, ts, test.ts)
		}
	}
}

func BenchmarkRange(b *testing.B) {
	for i := 0; i < b.N; i++ {
		Range(1, 100)
	}
}

func BenchmarkSum(b *testing.B) {
	for i := 0; i < b.N; i++ {
		Sum(1000)
	}
}

Version data entries

158 entries across 158 versions & 1 rubygems

Version Path
trackler-2.2.1.56 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.55 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.54 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.53 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.52 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.51 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.50 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.49 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.48 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.47 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.46 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.45 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.44 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.43 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.42 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.41 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.40 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.39 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.38 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go
trackler-2.2.1.37 tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go