大規模ウェブサイトのアルゴリズムとアーキテクチャに関する簡単な説明

大規模ウェブサイトのアルゴリズムとアーキテクチャに関する簡単な説明

順序

先月、上司が「大規模ウェブサイトのアルゴリズムとアーキテクチャに関する簡単な説明」という講義をしてくれて、とても役に立ちました。記事が長すぎるため(データ構造だけでもおそらく 20 種類以上あります)、一度にすべてを理解することができませんので、理解したとおりに章ごとに共有します。

今週は、さまざまなデータ構造とアルゴリズムを理解するために資料を調べました。

個人的に良いと思う本をいくつかお勧めします。 - 電子書籍をここに置きました: http://download.csdn.net/user/rtxbc。ダウンロードする必要がある場合は、ここからダウンロードしてください。

「ポインタの芸術。蔡明志」 - 私は C 言語に関する部分だけを読みました。個人的には、C 言語で最も難しいのはポインターだと感じています。

「C言語を使用したデータ構造 [Zhu Zhanli]」 - Yan Weimin の本も良いのですが、その中の文法の多くは抽象文法であり、実行できません。個人的には、ターミナルで実行する方法がなければ、感心するのは難しいと思います。

アルゴリズム入門

勉強のためにダウンロードした電子書籍(スクリーンショット):

アルゴリズムの構造

導入

1984年、パスカルセマンティクスと構造化プログラミングの革新により、ヴォスは「アルゴリズム + データ構造 = プログラム」を提案し、その年にチューリング賞を受賞しました。

現在、テクノロジーは日々変化しており、インターネットテクノロジーは絶えず発展し、歴史に新たな一章を開いています。このとき、「アルゴリズム + アーキテクチャ = インターネット プログラム」を提案する人もいました。

この時代を生きるプログラマーにとって、これは何を意味するのでしょうか?

この記事から、大規模な Web サイトのアルゴリズムとアーキテクチャについて簡単に説明します。今日はまず基本を理解し、その後徐々に移行していきます。

#p#

検索アルゴリズム(スタンドアロン)

1. 順序付けられていない配列があります。

2. 7 から 20 までの数字を見つけるには、どのようなアイデアがありますか?

次の2点は不思議ではありません。

1. バブルソート

2》二分探索は高速

3. Cコードの実装

[[94764]]実行結果

#p#

配列にデータを挿入する

配列の問題: 挿入が遅すぎるため、データを移動する必要があります。

次のコードをご覧ください。

[[94764]]実行結果

リンクリストを試す

[[94764]]コード構造

リンクリストにデータを挿入する

[[94764]]

リンクリストの特徴は、挿入が高速で、検索が低速であることです。

コード実装:

[[94764]]実装

#p#

実行プロセスをご覧ください

つまり、バイナリツリー(Binary Tree)が存在するのです。

上記の 2 つの構造 (配列とリンク リスト) にはそれぞれ欠点があることに気づくのは難しくありません。

1》配列は更新時に多くのリソースを消費し、後続の要素を1つずつ移動する必要があります。

2》リンクリストを照会する場合は、先頭から1つずつ比較して、照会する内容を選択する必要があります。

要約すると、クエリと更新がより高速な構造が必要なので、バイナリ ツリーを使用します。記事が長くなりすぎたので、次回の記事で紹介を続けます。

オリジナルリンク: http://www.cnblogs.com/baochuan/archive/2012/09/27/2704994.html

<<:  大規模ウェブサイトのアルゴリズムとアーキテクチャについての簡単な説明(パート 2)

>>:  アルゴリズム設計者が新たな人気者になる

ブログ    
ブログ    
ブログ    
ブログ    

推薦する

...

Transformerを廃止すれば、完全な畳み込みネットワークでもE2E検出を実現できる。

研究者は最近、ターゲット検出のための Transformer の使用を熱心に研究していますが、この論...

視線追跡は無視できない、視覚制御車はもうすぐ登場する

正直に言ってみましょう。ジョブズが2007年に初めてiPhoneをリリースしたとき、革命的な新時代が...

人工知能は、マルチドメイン畳み込みニューラルネットワークを通じて、JPEG二重圧縮画像内の偽造領域を特定します。

人工知能がマルチドメイン畳み込みニューラル ネットワークを介して JPEG 二重圧縮画像の偽造領域を...

...

...

第14次5カ年計画期間中、我が国のドローン産業の発展はますます明確になりました

[[421133]]ドローン産業の発展レベルは、国の軍事力、科学技術革新、製造レベルを測る重要な指標...

スイスマイルは、立って都市部での配達に使用できる四足歩行の車輪付きロボットを披露した。

New Atlas によると、ETH チューリッヒの ANYmal ロボットは、4 本足で歩くだけ...

AI を活用して建設現場の活動を監視

[[348520]]建設現場は、人々とピースが適切なタイミングで組み合わさる必要がある巨大なパズルの...

...

...

タイタンの爆発で5人の裕福な人が亡くなりました! AIが最後の恐ろしい瞬間を再現、設計上の欠陥の真実が明らかに

4日間行方不明になっていた深海潜水艇「タイタン」は、予期せぬ壊滅的な爆発事故に見舞われた。乗組員5人...

何?ニューラルネットワークは新しい知識も生み出せるのでしょうか?

作業を実行するための明示的なアルゴリズムを知らなくても、特定のタスク用にニューラル ネットワーク (...

人工知能はすでに人間の減量を手助けするのに忙しい

今日はカロリーを消費しましたか?近年、生活水準の向上や生活習慣の変化に伴い、肥満は徐々に多くの人々を...

年末総括: 2021 年の人工知能 (AI) と機械学習 (ML) の 5 つの主要な開発トレンド

[[359772]]来年、AI テクノロジーはビジネス業務にさらに深く浸透するでしょう。人工知能 (...