1 Star 0 Fork 0

Fantix King/muts

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
math.mbt 954 Bytes
一键复制 编辑 原始数据 按行查看 历史
Fantix King 提交于 2024-03-04 02:07 +08:00 . 用新 for 替换剩余的 while
/// 比较并返回两个值中较大的那一个。
///
/// 如果两个值相等则返回第二个值。
///
pub fn max[T : Compare](x : T, y : T) -> T {
if x > y {
x
} else {
y
}
}
/// 比较并返回两个值中较小的那一个。
///
/// 如果两个值相等则返回第二个值。
///
pub fn min[T : Compare](x : T, y : T) -> T {
if x < y {
x
} else {
y
}
}
/// 可相加的接口。
pub trait Add {
op_add(Self, Self) -> Self
}
/// 将数组每一个元素按顺序相加。
///
pub fn sum[T : Add + Default](a : Array[T]) -> T {
let len = a.length()
for rv = T::default(), i = 0
i < len
rv = rv + a[i], i = i + 1 {
} else { rv }
}
test "math" {
assert_eq(max(6, 8), 8)
assert_eq(max(8, 6), 8)
assert_eq(min(6, 8), 6)
assert_eq(min(8, 6), 6)
assert_eq(sum([1, 2, 3, 4, 5]), 15)
assert_eq(sum([]), 0)
assert_eq(sum(["hello, ", "world"]), "hello, world")
assert_eq(sum([]), "")
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/fantix/muts.git
git@gitee.com:fantix/muts.git
fantix
muts
muts
v0.5.2

搜索帮助