C はべき乗を見つけるための複数のメソッドを提供します。底と指数パラメーターを受け入れる pow() 関数または std::pow() 関数を使用します。ループを使用して、正の整数の指数の場合、底と指数倍を掛けます。二分探索アルゴリズムを使用して、分割統治法を通じて検出力をすばやく見つけます。負の整数の指数の場合は、1 / power(base, -exponent) という式を使用して計算します。
#C のパワーを上げる関数
C でパワーを上げる方法はたくさんあります。最も簡単な方法は、base と exponent の 2 つのパラメータを受け入れるpow() 関数を使用することです。例:
<code class="cpp">#include <cmath> int main() { double base = 2.0; int exponent = 3; double result = pow(base, exponent); // 结果为 8.0 }</code>
std::pow() 関数を使用できます。この関数は、ベース、整数指数、ターゲット タイプの 3 つのパラメーターを受け入れます。例:
<code class="cpp">#include <cmath> int main() { int base = 2; int exponent = 3; int result = std::pow(base, exponent, long long); // 结果为 8 }</code>
<code class="cpp">int power(int base, int exponent) { int result = 1; for (int i = 0; i < exponent; i++) { result *= base; } return result; }</code>
<code class="cpp">int power(int base, int exponent) { if (exponent == 0) { return 1; } else if (exponent < 0) { return 1 / power(base, -exponent); } else { int result = 1; for (int i = 0; i < exponent; i++) { result *= base; } return result; } }</code>
<code class="cpp">int power(int base, int exponent) { if (exponent == 0) { return 1; } else if (exponent < 0) { return 1 / power(base, -exponent); } else { int result = 1; while (exponent > 0) { if (exponent % 2 == 1) { result *= base; } base *= base; exponent /= 2; } return result; } }</code>
以上がC++で検出力を求める関数の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。