diff options
| author | Ondřej Surý <ondrej@sury.org> | 2012-04-06 15:14:11 +0200 | 
|---|---|---|
| committer | Ondřej Surý <ondrej@sury.org> | 2012-04-06 15:14:11 +0200 | 
| commit | 505c19580e0f43fe5224431459cacb7c21edd93d (patch) | |
| tree | 79e2634c253d60afc0cc0b2f510dc7dcbb48497b /doc/progs/eff_sequence.go | |
| parent | 1336a7c91e596c423a49d1194ea42d98bca0d958 (diff) | |
| download | golang-505c19580e0f43fe5224431459cacb7c21edd93d.tar.gz | |
Imported Upstream version 1upstream/1
Diffstat (limited to 'doc/progs/eff_sequence.go')
| -rw-r--r-- | doc/progs/eff_sequence.go | 42 | 
1 files changed, 42 insertions, 0 deletions
| diff --git a/doc/progs/eff_sequence.go b/doc/progs/eff_sequence.go new file mode 100644 index 000000000..11c885abf --- /dev/null +++ b/doc/progs/eff_sequence.go @@ -0,0 +1,42 @@ +// Copyright 2009 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" +	"sort" +) + +func main() { +	seq := Sequence{6, 2, -1, 44, 16} +	sort.Sort(seq) +	fmt.Println(seq) +} + +type Sequence []int + +// Methods required by sort.Interface. +func (s Sequence) Len() int { +	return len(s) +} +func (s Sequence) Less(i, j int) bool { +	return s[i] < s[j] +} +func (s Sequence) Swap(i, j int) { +	s[i], s[j] = s[j], s[i] +} + +// Method for printing - sorts the elements before printing. +func (s Sequence) String() string { +	sort.Sort(s) +	str := "[" +	for i, elem := range s { +		if i > 0 { +			str += " " +		} +		str += fmt.Sprint(elem) +	} +	return str + "]" +} | 
