インタビュアー: アルゴリズムの時間計算量と空間計算量についてどう思いますか?計算方法は?

インタビュアー: アルゴリズムの時間計算量と空間計算量についてどう思いますか?計算方法は?

[[424483]]

1. はじめに

アルゴリズムとは、データを操作し、プログラムの問題を解決するために使用される一連の方法のことです。同じ問題に対して、異なるアルゴリズムを使用すると最終結果は同じになる可能性がありますが、プロセスで消費されるリソースと時間は大きく異なる場合があります。

さまざまなアルゴリズムの利点と欠点は、主に「時間」と「空間」という 2 つの次元を通じて測定されます。

  • 時間ディメンション: 現在のアルゴリズムの実行に費やされる時間を指し、通常は「時間複雑度」として表現されます。
  • 空間次元: 現在のアルゴリズムを実行するために必要なメモリ領域の量を指します。通常、これを説明するには「空間複雑度」を使用します。

時間と空間の次元を同時に考慮することができない状況に遭遇することが多く、両者のバランスを見つける必要があります。

アルゴリズムには通常、最良、平均、最悪の 3 つのケースがあります。通常は最悪のケースに焦点を当てます。

最悪のケースは、アルゴリズムの実行時間の上限です。一部のアルゴリズムでは、最悪のケースがより頻繁に発生します。つまり、平均的なケースは最悪のケースと同じくらい悪いということです。

2. 時間計算量

時間計算量とは、このアルゴリズムを実行するために必要な計算作業の量を指します。その計算量は、入力サイズが大きくなるにつれてプログラム実行時間の大きさを反映し、アルゴリズムの品質をほぼ反映します。

アルゴリズムにかかる時間は、アルゴリズム内のステートメントが実行される回数に比例します。ステートメントが実行される回数が増えるほど、かかる時間も長くなります。

アルゴリズムの複雑さは通常、ビッグ O 表記法で表され、T(n) = O(f(n)) と定義されます。一般的な時間複雑さには、次の図に示すように、O(1) 定数、O(log n) 対数、O(n) 線形、O(nlogn) 線形対数、O(n^2) 平方、O(n^3) 立方、O(n^k) k 乗、および O(2^n) 指数があります。

上記から、問題のサイズ n が大きくなり続けると、上記の時間計算量も増加し続け、アルゴリズムの実行効率が低下することがわかります。小さい順から大きい順の順序は次のとおりです。

  1. Ο(1)<Ο(log n)<Ο(n)<Ο(nlog n)<Ο(n2)<Ο(n3)<…<Ο(2^n)<Ο(n!)

アルゴリズムの複雑さは、アルゴリズムの成長傾向のみを表し、あるアルゴリズムが必ずしも他のアルゴリズムよりも効率的であることを意味するわけではないことに注意してください。定数項が大きすぎると、アルゴリズムの実行時間も長くなります。

時間の計算量を計算する方法については、次の簡単な例をご覧ください。

  1. 関数プロセス(n) {
  2. a = 1とする
  3. b = 2とする
  4. 合計をa + bとする
  5. ( i = 0; i < n; i++ とします) {
  6. 合計+= i
  7. }
  8. 戻る  
  9. }

関数アルゴリズムが実行する必要がある操作の数は、入力サイズnの関数として表されます。つまり、T(n) = 2 + n + 1の場合、時間計算量はO(n + 3)です。時間計算量は最大桁数のみに焦点を当てており、係数とは関係がないため、上記の時間計算量はO(n)です。

たとえば、次の例をご覧ください。

  1. 関数プロセス(n) {
  2. カウントを 0 にする
  3. ( i = 0; i < n; i++ とします){
  4. ( i = 0; i < n; i++ とします){
  5. カウント+= 1
  6. }
  7. }
  8. }

ループの中にネストされたループがあります。外側のループは 1 回実行され、内側のループは n 回実行されるため、時間計算量は O(n*n*1 + 2) = O(n^2) です。

順番に実行されるステートメントの場合、合計時間計算量は、次のように、それらの間の最大時間計算量に等しくなります。

  1. 関数プロセス(n) {
  2. 合計を0とする
  3. ( i = 0; i < n; i++ とします) {
  4. 合計+= i
  5. }
  6. ( i = 0; i < n; i++ とします){
  7. ( i = 0; i < n; i++ とします){
  8. 合計+= 1
  9. }
  10. }
  11. 戻る  
  12. }

最初の部分の複雑さは O(n)、2 番目の部分の複雑さは O(n^2)、合計の複雑さは max(O(n^2), O(n)) = O(n^2) です。

もう一つの例を挙げます。

  1. 関数プロセス(n) {
  2. i = 1; // ①
  3. (i <= n) の間 {
  4. i = i * 2; // ②
  5. }
  6. }

ループ ステートメントでは、n は 2 の倍数で近似され、そのたびに 2 が乗算されます。これを数式で表すと、1 * 2 * 2 * 2 … * 2 <= nとなり、これは2のx乗がn以下のときにループ本体が実行され、2^x <= nと記録されるので、x<=lognとなる。

したがって、ループはlogn回実行した後に終了するため、時間計算量はO(logn)となる。

同様に、O(n) ループが O(logn) ループ内にネストされている場合、時間の計算量は O(nlogn) です。たとえば、O(n^3) は、O(n) ループの 3 つの層にすぎません。

3. 空間の複雑さ

空間複雑度は主に、アルゴリズムの実行に必要なメモリのサイズを指し、プログラムの実行プロセス中に必要な一時的なストレージ領域を測定するために使用されます。

記憶領域、命令、定数、変数、入力データに加えて、データを操作する作業単位や計算に必要な情報を格納する補助領域も含まれます。

以下は空間計算量が O(1) の例です。

  1. a = 1とする
  2. b = 2とする
  3. c = 3とする

上記のコードの一時空間はnの変化によって変化しないので、空間計算量はO(1)である。

  1. arr [] を鳴らす
  2. (i=1; i<=n; ++i)の場合{
  3. arr.push(i)
  4. }

上でわかるように、nが増加すると、配列が占めるメモリ空間は大きくなります。

一般的に言えば、アルゴリズムが動的に割り当てられたスペース、再帰、およびスタックに必要なスペースを伴わない限り、スペースの複雑さは通常 O(1) です。1 次元配列 a[n] のスペースの複雑さは O(n) で、2 次元配列のスペースの複雑さは O(n^2) です。

参考文献

  • https://juejin.cn/post/6844904167824162823#heading-7
  • https://zhuanlan.zhihu.com/p/50479555
  • https://cloud.tencent.com/developer/article/1769988

<<:  MITはレーザー彫刻機にAIを搭載し、材料を自動的に識別し、98%の精度で彫刻の強度を判定した。

>>:  成功するAIチームの特徴

ブログ    
ブログ    

推薦する

本当に滑らか: 浙江大学、ETH チューリッヒ、CityU が共同で開発した 3D ヘア モデリングの新しい手法、NeuralHDHair

近年、バーチャルデジタルヒューマン業界は大変人気が高まっており、あらゆる分野の人々が独自のデジタルヒ...

...

2019年ロボカップのハイライト!人間が4対1で勝利し、中国チームが多くの賞を獲得した

[[271788]]今月、オーストラリアのシドニーで2019年ロボカップ(ロボットワールドカップ)が...

Google の FLoC アルゴリズムは、プライバシー保護の向上か、広告テクノロジーの向上か?

Android システムでは、Nut Hidden APP をダウンロードして、セキュリティリスク...

...

顔認証決済はまだ普及していないが、中央銀行はすでに新しい決済方法を発表しており、ジャック・マーは今回不意を突かれた

顔認識の隠れた危険性これらの便利な支払い方法が普及したのは、ジャック・マーのおかげです。アリペイの登...

プライベートコレクション、オープンソースのトップディープラーニングプロジェクト9つ

[[203962]]過去数年間で、コンピューター科学者は人工知能 (AI) の分野で大きな飛躍を遂げ...

...

72歳の男性がコーラを飲みながら脳で麻雀をする:これはすべて脳コンピューターインターフェース技術のおかげです

浙江省メディアの報道によると、現在浙江大学医学部第二付属病院で治療を受けている72歳の張さんは、意識...

人工知能技術が農業に革命を起こす

国際的に著名な学者である周海中教授は、1990年代に「科学技術の進歩により、人工知能の時代が到来しよ...

200 の優れた機械学習チュートリアルの要約「史上最も完全」

この記事には、これまでで最も優れたチュートリアル コンテンツであると一般に考えられている内容が含まれ...

中山大学、AIGCの大規模応用を促進するためにソース拡散モデル統合コードフレームワークを公開

近年、拡散モデルに基づく画像生成モデルが次々と登場し、驚くべき生成効果を示しています。しかし、関連す...

スマート、インテリジェントなインタラクティブ推奨システムと販売前ショッピングガイドロボットをリリース

昨日、北京のマイクロソフトビルでSmarterが開催されました。カンファレンスのテーマは「インテリジ...

2018 CCF BDCIコンペティションのグローバルローンチ:データ駆動型、スマートな未来

8月11日、2018年のCCFビッグデータ&Computational Intelligenceコン...

...