2 回答

TA贡献1851条经验 获得超4个赞
怎么样
const bigIntMax = (...args) => args.reduce((m, e) => e > m ? e : m);
const bigIntMin = (...args) => args.reduce((m, e) => e < m ? e : m);
如果你想要两个
const bigIntMinAndMax = (...args) => {
return args.reduce(([min,max], e) => {
return [
e < min ? e : min,
e > max ? e : max,
];
}, [args[0], args[0]]);
};
const [min, max] = bigIntMinAndMax(
BigInt(40),
BigInt(50),
BigInt(30),
BigInt(10),
BigInt(20),
);

TA贡献1757条经验 获得超8个赞
经过一番谷歌搜索后,答案似乎是否定的,Javascript 对此没有内置函数。
这是与内置签名匹配的 bigint 的 min 和 max 的实现,除了它会为空列表引发错误(而不是返回 +/-Infinity,因为 BigInt 不能表示无穷大):
function bigint_min(...args){
if (args.length < 1){ throw 'Min of empty list'; }
m = args[0];
args.forEach(a=>{if (a < m) {m = a}});
return m;
}
function bigint_max(...args){
if (args.length < 1){ throw 'Max of empty list'; }
m = args[0];
args.forEach(a=>{if (a > m) {m = a}});
return m;
}
添加回答
举报