コンテンツにスキップ
メインメニュー
メインメニュー
サイドバーに移動
非表示
案内
メインページ
最近の更新
未作成ページ
おまかせ表示
ヘルプ
MonoBook
検索
検索
ログイン
個人用ツール
ログイン
ログアウトした編集者のページ
もっと詳しく
投稿記録
トーク
「
累乗
」を編集中
ページ
議論
日本語
閲覧
編集
ソースを編集
履歴表示
ツール
ツール
サイドバーに移動
非表示
操作
閲覧
編集
ソースを編集
履歴表示
全般
リンク元
関連ページの更新状況
特別ページ
ページ情報
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。
スパム攻撃防止用のチェックです。 けっして、ここには、値の入力は
しない
でください!
'''累乗'''(るいじょう、[[英語]]:repeated multiplication)とは、[[冪乗]](べきじょう)の[[指数]]部が「1以上の[[自然数]]([[整数]])」なものをいう。 ほとんどの[[プログラミング言語]]には[[冪乗]]を計算する[[関数]]は標準搭載されているが、累乗を計算する関数はないことが多く、累乗の計算は冪乗の結果を[[整数]]に[[キャスト]]することで得るようになっていることが多い。 <source lang="csharp"> // 冪乗関数はこんな感じ double Math.Pow(double x, double y); // 累乗は結果をキャストすることで得るようになっていることが多い。 int r = (int)Math.Pow(3,11); </source> ただし[[冪乗]]の計算は自然数以外(浮動小数点)も扱える汎用性の高さの代償として非常に計算量が多いため、累乗(指数部に整数)しか使わないのであれば自前で簡単な関数を実装した方が高速な場合が多い。 <source lang="csharp"> using System; using BenchmarkDotNet.Attributes; using BenchmarkDotNet.Running; public class Program { public static void Main(string[] args) { var switcher = BenchmarkRunner.Run<Program>(); } // 冪乗の結果をキャストする [Benchmark] [Arguments(3, 11)] public int PowA(int x, uint exponent) { return (int)Math.Pow(x, exponent); } // 累乗:教科書どおりの力技 [Benchmark] [Arguments(3,11)] public int PowB(int x, uint exponent) { int r = 1; for (int n = 0; n < exponent; n++) { r = r * x; } return r; } // 累乗:アルゴリズム最適化 [Benchmark] [Arguments(3, 11)] public int PowC(int x, uint exponent) { int ret = 1; while (exponent != 0) { if ((exponent & 1) == 1) {// 奇数 ret *= x; } x *= x; exponent >>= 1; } return ret; } } </source>
編集内容の要約:
MonoBookへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
MonoBook:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
このページを編集するには、下記の確認用の質問に回答してください (
詳細
):
1たす1は?(全角で入力してください)
キャンセル
編集の仕方
(新しいウィンドウで開きます)
本文の横幅制限を有効化/無効化