blob: 64230060de7f3478bcba960570b2929752fc17e7 [file] [log] [blame]
// run -gcflags=-G=3
// Copyright 2021 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package main
import (
"fmt"
)
type Ordered interface {
type int, int8, int16, int32, int64,
uint, uint8, uint16, uint32, uint64, uintptr,
float32, float64,
string
}
// List is a linked list of ordered values of type T.
type list[T Ordered] struct {
next *list[T]
val T
}
func (l *list[T]) largest() T {
var max T
for p := l; p != nil; p = p.next {
if p.val > max {
max = p.val
}
}
return max
}
func main() {
i3 := &list[int]{nil, 1}
i2 := &list[int]{i3, 3}
i1 := &list[int]{i2, 2}
if got, want := i1.largest(), 3; got != want {
panic(fmt.Sprintf("got %d, want %d", got, want))
}
b3 := &list[byte]{nil, byte(1)}
b2 := &list[byte]{b3, byte(3)}
b1 := &list[byte]{b2, byte(2)}
if got, want := b1.largest(), byte(3); got != want {
panic(fmt.Sprintf("got %d, want %d", got, want))
}
f3 := &list[float64]{nil, 13.5}
f2 := &list[float64]{f3, 1.2}
f1 := &list[float64]{f2, 4.5}
if got, want := f1.largest(), 13.5; got != want {
panic(fmt.Sprintf("got %f, want %f", got, want))
}
s3 := &list[string]{nil, "dd"}
s2 := &list[string]{s3, "aa"}
s1 := &list[string]{s2, "bb"}
if got, want := s1.largest(), "dd"; got != want {
panic(fmt.Sprintf("got %s, want %s", got, want))
}
}