mirror of https://github.com/01-edu/public.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
1.3 KiB
67 lines
1.3 KiB
5 years ago
|
package main
|
||
5 years ago
|
|
||
|
import (
|
||
|
"reflect"
|
||
|
|
||
5 years ago
|
"./student"
|
||
5 years ago
|
)
|
||
|
|
||
5 years ago
|
func compact(slice *[]string) int {
|
||
|
count := 0
|
||
|
var compacted []string
|
||
|
for _, v := range *slice {
|
||
|
if v != "" {
|
||
|
count++
|
||
|
compacted = append(compacted, v)
|
||
|
}
|
||
|
}
|
||
|
*slice = compacted
|
||
|
return count
|
||
|
}
|
||
|
|
||
5 years ago
|
func main() {
|
||
|
arg := [][]string{{"hello", "", "hi", "", "salut", "", ""}}
|
||
5 years ago
|
|
||
|
for i := 0; i < 20; i++ {
|
||
5 years ago
|
n := lib.RandIntBetween(5, 20) // random size of the slice
|
||
5 years ago
|
|
||
5 years ago
|
orig := make([]string, n) // slice with the original value
|
||
5 years ago
|
|
||
5 years ago
|
num_pos := lib.RandIntBetween(1, n-1) // random number of positions to be written
|
||
5 years ago
|
|
||
|
for i := 0; i < num_pos; i++ {
|
||
5 years ago
|
word := lib.RandWords() // random string value
|
||
|
rand_pos := lib.RandIntBetween(0, n-1) // random position in the slice
|
||
5 years ago
|
orig[rand_pos] = word
|
||
|
}
|
||
|
arg = append(arg, orig)
|
||
|
}
|
||
|
|
||
|
for _, v := range arg {
|
||
|
sli_sol := make([]string, len(arg)) // slice to apply the solution function
|
||
|
sli_stu := make([]string, len(arg)) // slice to apply the student function
|
||
|
|
||
|
copy(sli_sol, v)
|
||
|
copy(sli_stu, v)
|
||
|
|
||
5 years ago
|
sol_size := compact(&sli_sol)
|
||
5 years ago
|
stu_size := student.Compact(&sli_stu)
|
||
|
|
||
|
if !reflect.DeepEqual(sli_stu, sli_sol) {
|
||
5 years ago
|
lib.Fatalf("Produced slice: %v, instead of %v\n",
|
||
5 years ago
|
sli_stu,
|
||
|
sli_sol,
|
||
|
)
|
||
|
}
|
||
|
|
||
|
if sol_size != stu_size {
|
||
5 years ago
|
lib.Fatalf("%s(%v) == %v instead of %v\n",
|
||
5 years ago
|
"Compact",
|
||
|
v,
|
||
|
sli_stu,
|
||
|
sli_sol,
|
||
|
)
|
||
|
}
|
||
|
}
|
||
|
}
|