Created
          February 23, 2017 05:44 
        
      - 
      
- 
        Save vaskoz/667832ee08cc8569124adbfc97c3f762 to your computer and use it in GitHub Desktop. 
    Interesting to view the trace: go test -bench . -trace trace.out
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | package floyd | |
| import "sync" | |
| // FloydTriangle implements the triangle as a slice of slices based on | |
| // https://github.com/plutov/practice-go/tree/master/floyd | |
| func FloydTriangle(rows int) [][]int { | |
| if rows < 0 { | |
| panic("can't be less than zero") | |
| } | |
| return SerFloydTriangle(rows) | |
| //return ConcFloydTriangle(rows) | |
| } | |
| // SerialFloydTriangle a serial implementation | |
| func SerFloydTriangle(rows int) [][]int { | |
| counter := 1 | |
| result := make([][]int, rows) | |
| for row := 0; row < rows; row++ { | |
| result[row] = make([]int, row+1) | |
| for i := 0; i < row+1; i++ { | |
| result[row][i] = counter | |
| counter++ | |
| } | |
| } | |
| return result | |
| } | |
| // ConcurrentFloydTriange a concurrent implementation | |
| func ConcFloydTriangle(rows int) [][]int { | |
| counter := 1 | |
| result := make([][]int, rows) | |
| var wg sync.WaitGroup | |
| wg.Add(rows) | |
| for row := 0; row < rows; row++ { | |
| go func(r, c int) { | |
| result[r] = make([]int, r+1) | |
| for i := 0; i < r+1; i++ { | |
| result[r][i] = c | |
| c++ | |
| } | |
| wg.Done() | |
| }(row, counter) | |
| counter += (row + 1) | |
| } | |
| wg.Wait() | |
| return result | |
| } | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | package floyd | |
| import ( | |
| "testing" | |
| ) | |
| var tests = []struct { | |
| rowsCount int | |
| expected [][]int | |
| }{ | |
| {0, [][]int{}}, | |
| {1, [][]int{[]int{1}}}, | |
| {2, [][]int{[]int{1}, []int{2, 3}}}, | |
| {3, [][]int{[]int{1}, []int{2, 3}, []int{4, 5, 6}}}, | |
| {4, [][]int{[]int{1}, []int{2, 3}, []int{4, 5, 6}, []int{7, 8, 9, 10}}}, | |
| {5, [][]int{[]int{1}, []int{2, 3}, []int{4, 5, 6}, []int{7, 8, 9, 10}, []int{11, 12, 13, 14, 15}}}, | |
| {6, [][]int{[]int{1}, []int{2, 3}, []int{4, 5, 6}, []int{7, 8, 9, 10}, []int{11, 12, 13, 14, 15}, []int{16, 17, 18, 19, 20, 21}}}, | |
| } | |
| func TestFloydTriangle(t *testing.T) { | |
| for _, test := range tests { | |
| actual := FloydTriangle(test.rowsCount) | |
| if len(actual) != len(test.expected) { | |
| t.Fatalf("FloydTriangle(%d) expected length %d, got %d", test.rowsCount, len(test.expected), len(actual)) | |
| } | |
| for k, v := range test.expected { | |
| if len(actual[k]) != len(v) { | |
| t.Fatalf("FloydTriangle(%d) expected length %d for row %d, got %d", test.rowsCount, len(v), k, len(actual[k])) | |
| } | |
| for k2, v2 := range v { | |
| if actual[k][k2] != v2 { | |
| t.Fatalf("FloydTriangle(%d) expected %d for row %d and column %d, got %d", test.rowsCount, v2, k, k2, actual[k][k2]) | |
| } | |
| } | |
| } | |
| } | |
| } | |
| func BenchmarkTestFloydTriangle(b *testing.B) { | |
| for i := 0; i < b.N; i++ { | |
| for _, test := range tests { | |
| FloydTriangle(test.rowsCount) | |
| } | |
| } | |
| } | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment