-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgoderive.go
65 lines (56 loc) · 1.26 KB
/
goderive.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package main
import (
"flag"
"fmt"
"os"
"strconv"
"strings"
)
func inputEquation(order *int, args []int) string {
var buffer strings.Builder
for i := 0; i <= *order; i++ {
if *order-i == 0 {
buffer.WriteString(fmt.Sprintf("%d", args[i]))
} else if *order-i == 1 {
buffer.WriteString(fmt.Sprintf("%dx + ", args[i]))
} else {
buffer.WriteString(fmt.Sprintf("%dx^%d + ", args[i], *order-i))
}
}
return buffer.String()
}
func outputEquation(args []int) string {
var buffer strings.Builder
var d int
order := len(args) - 1
for i := order; i > 0; i-- {
d = args[len(args)-1-i] * i
if i > 2 {
buffer.WriteString(fmt.Sprintf("%dx^%d + ", d, order-1))
} else if i == 2 {
buffer.WriteString(fmt.Sprintf("%dx + ", d))
} else {
buffer.WriteString(fmt.Sprintf("%d ", d))
}
}
return buffer.String()
}
func main() {
order := flag.Int("order", -1, "The order of the equation to be derived")
flag.Parse()
args := flag.Args()
if len(args) != *order+1 {
os.Exit(1)
}
intArgs := make([]int, len(args))
for i, val := range args {
if j, err := strconv.Atoi(val); err != nil {
os.Exit(1)
} else {
intArgs[i] = j
}
}
fmt.Println(inputEquation(order, intArgs))
fmt.Println("Deriving...")
fmt.Println(outputEquation(intArgs))
}