【剣指offer】10.プログラムの完全性
1204 ワード
問題1数値の整数乗
ダブルタイプの浮動小数点ベースとintタイプの整数exponentを指定します.baseのexponentの次の方を求めます.
考え方
この問題は論理的には簡単ですが、間違いやすいです.
すべての状況を考慮して、全面的に考えることが肝心です.
exponentがプラス、マイナス、0の場合
ベースが0の場合.
コード
すべての奇数が配列の前半に位置し、すべての偶数が配列の後半に位置し、奇数と奇数、偶数と偶数の間の相対的な位置が不変であるように、整数配列を入力します.
コード
ダブルタイプの浮動小数点ベースとintタイプの整数exponentを指定します.baseのexponentの次の方を求めます.
考え方
この問題は論理的には簡単ですが、間違いやすいです.
すべての状況を考慮して、全面的に考えることが肝心です.
exponentがプラス、マイナス、0の場合
ベースが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);
}