init
This commit is contained in:
commit
d61956e0fa
27
license
Normal file
27
license
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
Copyright (c) 2016, stephen mcquay
|
||||||
|
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
* Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
* Neither the name of bandwidth nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||||
|
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
83
main.go
Normal file
83
main.go
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
"sort"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
s := bufio.NewScanner(os.Stdin)
|
||||||
|
max := 0
|
||||||
|
r := results{}
|
||||||
|
for s.Scan() {
|
||||||
|
if len(s.Text()) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if len(s.Text()) > max {
|
||||||
|
max = len(s.Text())
|
||||||
|
}
|
||||||
|
r = append(r, result{s.Text(), freq(s.Text())})
|
||||||
|
}
|
||||||
|
if err := s.Err(); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
sort.Sort(r)
|
||||||
|
|
||||||
|
f := fmt.Sprintf("%%%ds: %%v", max)
|
||||||
|
for _, r := range r {
|
||||||
|
fmt.Printf(f+"\n", r.name, r.h)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type letter struct {
|
||||||
|
r rune
|
||||||
|
count int
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l letter) String() string {
|
||||||
|
return fmt.Sprintf("%v: %d", string(l.r), l.count)
|
||||||
|
}
|
||||||
|
|
||||||
|
type result struct {
|
||||||
|
name string
|
||||||
|
h histogram
|
||||||
|
}
|
||||||
|
|
||||||
|
type results []result
|
||||||
|
|
||||||
|
func (r results) Len() int { return len(r) }
|
||||||
|
func (r results) Swap(i, j int) { r[i], r[j] = r[j], r[i] }
|
||||||
|
func (r results) Less(i, j int) bool {
|
||||||
|
if len(r[i].h) == 0 || len(r[j].h) == 0 {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return r[i].h[0].count > r[j].h[0].count
|
||||||
|
}
|
||||||
|
|
||||||
|
type histogram []letter
|
||||||
|
|
||||||
|
func (n histogram) Len() int { return len(n) }
|
||||||
|
func (n histogram) Swap(i, j int) { n[i], n[j] = n[j], n[i] }
|
||||||
|
func (n histogram) Less(i, j int) bool {
|
||||||
|
return n[i].count > n[j].count
|
||||||
|
}
|
||||||
|
|
||||||
|
func freq(in string) histogram {
|
||||||
|
m := map[rune]int{}
|
||||||
|
for _, r := range in {
|
||||||
|
if r == ' ' {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
m[r]++
|
||||||
|
}
|
||||||
|
|
||||||
|
r := histogram{}
|
||||||
|
for k, v := range m {
|
||||||
|
r = append(r, letter{k, v})
|
||||||
|
}
|
||||||
|
sort.Sort(r)
|
||||||
|
return r
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user