第一种方式(先排序在取值)
- sort:原有数组发生改变;先用sort(function(a,b){return a-b})或者sort(function(a,b){return b-a})对数组进行排序,然后取数组的最后一项或者第一项
var ary = [12, 45, 7, 8, 13, 12, 99,12,31];
ary.sort(function (a, b) {
return a - b;
});
var max = ary[ary.length - 1];
console.log(max);//=>99
//利用冒泡的方式,相邻两项比较,交换位置
let ary = [12, 45, 7, 8, 13, 12, 99];
for (let i = 0; i < ary.length; i++) {
if (ary[i] > ary[i + 1]) {
let temp = ary[i];
ary[i] = ary[i + 1];
ary[i + 1] = temp;
}
}
let max = ary[ary.length - 1];
console.log(max);
第二种方式(假设法)
- 假设法的思想:假设一个最大值(一般选第一个或者是最后一个,方便比较),让数组中的每一项和max相比,如果比max大,就用该值重新赋值给max,反之,什么也不做
let max = ary[0];
for (let i = 1; i < ary.length; i++) {
if (ary[i] > max) {
max = ary[i];
}
}
console.log(max);//=>99
第三种方法(利用Math.max())
let ary = [12, 45, 7, 8, 13, 12, 99];
//...(ES6中的展开运算符)
console.log(Math.max(...ary));//=>99
let ary = [12, 45, 7, 8, 13, 12, 99];
console.log(Math.max.apply(null, ary));//=>99