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.

91 lines
1.7 KiB

package main
import (
"./correct"
"github.com/01-edu/public/go/lib"
)
type stuNode = NodeAddL
type solNode = correct.NodeAddL
func stuPushFront(node *stuNode, num int) *stuNode {
tmp := &stuNode{Num: num}
tmp.Next = node
return tmp
}
func stuNumToList(num int) *stuNode {
var res *stuNode
for num > 0 {
res = stuPushFront(res, num%10)
num /= 10
}
return res
}
func stuListToNum(node *stuNode) int {
var n int
for tmp := node; tmp != nil; tmp = tmp.Next {
n = n*10 + tmp.Num
}
return n
}
func solPushFront(node *solNode, num int) *solNode {
tmp := &solNode{Num: num}
tmp.Next = node
return tmp
}
func solNumToList(num int) *solNode {
var res *solNode
for num > 0 {
res = solPushFront(res, num%10)
num /= 10
}
return res
}
func solListToNum(node *solNode) int {
var n int
for tmp := node; tmp != nil; tmp = tmp.Next {
n = n*10 + tmp.Num
}
return n
}
func compareNodes(stuResult *stuNode, solResult *solNode, num1 int) {
if stuResult == nil && solResult == nil {
return
}
if stuResult != nil && solResult == nil {
stuNum := stuListToNum(stuResult)
lib.Fatalf("\nSortll(%d) == %v instead of %v\n\n",
num1, stuNum, "")
}
if stuResult == nil && solResult != nil {
solNum := solListToNum(solResult)
lib.Fatalf("\nSortll(%d) == %v instead of %v\n\n",
num1, "", solNum)
}
stuNum := stuListToNum(stuResult)
solNum := solListToNum(solResult)
if stuNum != solNum {
lib.Fatalf("\nSortll(%d) == %v instead of %v\n\n",
num1, stuNum, solNum)
}
}
func main() {
table := []int{123456}
table = append(table, lib.MultRandIntBetween(0, 1000000000)...)
for _, arg := range table {
stuResult := Sortll(stuNumToList(arg))
solResult := correct.Sortll(solNumToList(arg))
compareNodes(stuResult, solResult, arg)
}
}