问题1 数值的整数次方
给定一个double范例的浮点数base和int范例的整数exponent。求base的exponent次方。
思绪
这道题逻辑上很简单,但很轻易失足。
关键是要斟酌周全,斟酌到一切状况。
exponent 是正,负,0的状况
base为0的状况。
代码
function Power(base, exponent) {
if (exponent === 0) {
return 1;
} else {
if (exponent > 0) {
var result = 1;
for (let i = 0; i < exponent; i++) {
result *= base;
}
return result;
} else if (exponent < 0) {
var result = 1;
for (let i = 0; i < Math.abs(exponent); i++) {
result *= base;
}
return result ? 1 / result : false;
}
}
}
问题2 调解数组递次使奇数位于偶数前面
输入一个整数数组,完成一个函数来调解该数组中数字的递次,使得一切的奇数位于数组的前半部份,一切的偶数位于数组的后半部份,并保证奇数和奇数,偶数和偶数之间的相对位置稳定。
代码
function reOrderArray(array) {
var odd = [];
var even = [];
for (var i = 0; i < array.length; i++) {
const element = array[i];
if (element === 0 || element % 2 === 0) {
even.push(element);
} else {
odd.push(element);
}
}
return odd.concat(even);
}