The challenge
Your goal is to return multiplication table for number
that is always an integer from 1 to 10.
For example, a multiplication table (string) for number == 5
looks like below:
1 * 5 = 5
2 * 5 = 10
3 * 5 = 15
4 * 5 = 20
5 * 5 = 25
6 * 5 = 30
7 * 5 = 35
8 * 5 = 40
9 * 5 = 45
10 * 5 = 50
P. S. You can use \n
in string to jump to the next line.
Note: newlines should be added between rows, but there should be no trailing newline at the end.
The solution in Golang
Option 1:
package solution
import (
"fmt"
"strings"
)
func MultiTable(number int) string {
superstring := ""
for i := 1; i < 11; i++ {
superstring += fmt.Sprintf("%d * %d = %d\n", i, number, number * i)
}
return strings.TrimRight(superstring, "\n")
}
Option 2:
package solution
import "fmt"
func MultiTable(number int) (res string) {
for i := 1; i <= 10; i++ {
res += fmt.Sprintf("%d * %d = %d\n", i, number, number*i)
}
return res[:len(res)-1]
}
Option 3:
package solution
import "fmt"
import "strings"
func MultiTable(number int) string {
var s []string
for i := 1; i <= 10; i++ {
s = append(s, fmt.Sprintf("%d * %d = %d", i, number, i*number))
}
return strings.Join(s[:],"\n")
}
Test cases to validate our solution
package our_test
import (
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
)
var _ = Describe("Test MultiTable", func() {
It("should handle basic cases", func() {
Expect(MultiTable(5)).To(Equal("1 * 5 = 5\n2 * 5 = 10\n3 * 5 = 15\n4 * 5 = 20\n5 * 5 = 25\n6 * 5 = 30\n7 * 5 = 35\n8 * 5 = 40\n9 * 5 = 45\n10 * 5 = 50"))
Expect(MultiTable(1)).To(Equal("1 * 1 = 1\n2 * 1 = 2\n3 * 1 = 3\n4 * 1 = 4\n5 * 1 = 5\n6 * 1 = 6\n7 * 1 = 7\n8 * 1 = 8\n9 * 1 = 9\n10 * 1 = 10"))
})
})