2023-02-01 15:52:09 +00:00
|
|
|
// Package number
|
|
|
|
// 使用随机数时需要先 调用 rand.seed()函数
|
2023-01-21 11:31:23 +00:00
|
|
|
package number
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2023-02-04 16:07:10 +00:00
|
|
|
"golang.org/x/exp/constraints"
|
2023-02-10 16:32:46 +00:00
|
|
|
"math"
|
2023-01-21 11:31:23 +00:00
|
|
|
"math/rand"
|
|
|
|
)
|
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Range[T constraints.Integer](start, end, step T) []T {
|
2023-01-21 11:31:23 +00:00
|
|
|
if step == 0 {
|
|
|
|
panic("step can't be 0")
|
|
|
|
}
|
|
|
|
l := int((end-start+1)/step + 1)
|
|
|
|
if l < 0 {
|
|
|
|
l = 0 - l
|
|
|
|
}
|
|
|
|
r := make([]T, 0, l)
|
|
|
|
for i := start; ; {
|
|
|
|
r = append(r, i)
|
|
|
|
i = i + step
|
|
|
|
if (step > 0 && i > end) || (step < 0 && i < end) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2023-01-27 15:48:48 +00:00
|
|
|
// Rand 都为闭区间 [start,end]
|
2023-02-04 16:07:10 +00:00
|
|
|
func Rand[T constraints.Integer](start, end T) T {
|
2023-01-21 11:31:23 +00:00
|
|
|
end++
|
|
|
|
return T(rand.Int63n(int64(end-start))) + start
|
|
|
|
}
|
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Min[T constraints.Integer | constraints.Float](a ...T) T {
|
2023-01-21 11:31:23 +00:00
|
|
|
min := a[0]
|
|
|
|
for _, t := range a {
|
|
|
|
if min > t {
|
|
|
|
min = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return min
|
|
|
|
}
|
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Max[T constraints.Integer | constraints.Float](a ...T) T {
|
2023-01-21 11:31:23 +00:00
|
|
|
max := a[0]
|
|
|
|
for _, t := range a {
|
|
|
|
if max < t {
|
|
|
|
max = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return max
|
|
|
|
}
|
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Sum[T constraints.Integer | constraints.Float](a ...T) T {
|
2023-01-21 11:31:23 +00:00
|
|
|
s := T(0)
|
|
|
|
for _, t := range a {
|
|
|
|
s += t
|
|
|
|
}
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Add[T constraints.Integer | constraints.Float](i, j T) T {
|
2023-01-27 15:48:48 +00:00
|
|
|
return i + j
|
|
|
|
}
|
2023-02-04 16:07:10 +00:00
|
|
|
func Sub[T constraints.Integer | constraints.Float](i, j T) T {
|
2023-01-28 13:38:34 +00:00
|
|
|
return i - j
|
|
|
|
}
|
2023-01-27 15:48:48 +00:00
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func ToString[T constraints.Integer | constraints.Float](n T) string {
|
2023-01-21 11:31:23 +00:00
|
|
|
return fmt.Sprintf("%v", n)
|
|
|
|
}
|
2023-01-27 15:48:48 +00:00
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Abs[T constraints.Integer | constraints.Float](n T) T {
|
2023-01-27 15:48:48 +00:00
|
|
|
if n >= 0 {
|
|
|
|
return n
|
|
|
|
}
|
|
|
|
return -n
|
|
|
|
}
|
2023-01-28 13:38:34 +00:00
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Mul[T constraints.Integer | constraints.Float](i, j T) T {
|
2023-01-28 13:38:34 +00:00
|
|
|
return i * j
|
|
|
|
}
|
|
|
|
|
2023-02-04 16:07:10 +00:00
|
|
|
func Divide[T constraints.Integer | constraints.Float](i, j T) T {
|
2023-01-28 13:38:34 +00:00
|
|
|
return i / j
|
|
|
|
}
|
2023-02-10 16:32:46 +00:00
|
|
|
|
|
|
|
func CalTotalPage[T constraints.Integer](totalRows, size T) T {
|
|
|
|
return T(math.Ceil(float64(totalRows) / float64(size)))
|
|
|
|
}
|
2023-03-19 12:40:08 +00:00
|
|
|
|
|
|
|
type Counter[T constraints.Integer] func() T
|
|
|
|
|
|
|
|
func Counters[T constraints.Integer]() func() T {
|
|
|
|
var count T
|
|
|
|
return func() T {
|
|
|
|
count++
|
|
|
|
return count
|
|
|
|
}
|
|
|
|
}
|