JS チュートリアル -- 動的計画法アルゴリズムのナップザック容量問題
ナップザック問題
質問
アイテムNと容量Vのナップザックが与えられたとき、アイテムiの体積はwiで、その値はciです。
(各アイテムは1つだけあります)
Q: バックパックに入れるアイテムの合計価値が最大になるように、バックパックに入れるアイテムを選択するにはどうすればよいですか?
各アイテムを前に、選択肢は 2 つだけです。入れるか入れないかです。各アイテムは 1 回しか入れることができません。
先ほどと同じ考え方でもう一度試してみましょう
最後のアイテムしか残っていない場合、選択肢は2つあります
1. 残りのスペースが十分にある場合は、それを入れることを選択します
2. 残りのスペースが不足している場合、入れないでください
したがって、次の 2 つの最適な下部構造があります:
1. i-1 のアイテムを容量 V のバックパックに入れるという最適な選択
2. i- を容量 V-w のバックパックに入れる。 [i] 1 個のアイテムの最適な選択
つまり、要約すると、次のようになります:
容量 V のバックパックに i 個のアイテムを入れる最適な選択:
max (i-容量 V のバックパックに 1 つのアイテムを入れる 最適な選択は、容量 V-w[i] + c[i]) のバックパックに i-1 個のアイテムを入れることです
f[i][v] を使用して、 v の容量を持つ最初の i 個のアイテムを表します。バックパックに入れることができる最大値です。
副問題を使用して状態を定義します:
状態遷移方程式は次のとおりです: f[i] [v] = max{f[i-1] [v],f[i-1] [v-w[i]] +c[i]}。
まず、
バックパックの総容量は V = 12 であると仮定しましょう
アイテムの容量配列は w = [4, 6, 2, 2, 5, 1]
値の配列は c = [8, 10 、6、3、7、2]
f(i,v) = 0 (i
f(i,v) = c [0] (i= =1, v>=p[0]);
f(i,v) = f(i-1,v) (i>1, v
f(i,v) = max(f(i-1,v), f(i-1,v-w[i-1])+c[i-1])(i> ;1, v>= w[i-1])
左から右に進むたびに、前のデータが保存されます
上から下に進むと、前のデータが保存されます前の行
したがって、一般に保存する必要があるのは、1 行のデータの場合、空間複雑度は O(V) です
時間計算量は O(N*V)、空間複雑度は O(V) です
ただし、元の再帰的手法、つまり順列と組み合わせを使用すると、この手法を使用すると、時間計算量は O(2^N) になります
JS は動的プログラミング バックパック アルゴリズムを実装します
JavaScript の高度なアルゴリズム動的プログラミングのサンプル分析
以上がJS チュートリアル -- 動的計画法アルゴリズムのナップザック容量問題の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

JavaScript と WebSocket を使用してリアルタイム オンライン注文システムを実装する方法の紹介: インターネットの普及とテクノロジーの進歩に伴い、ますます多くのレストランがオンライン注文サービスを提供し始めています。リアルタイムのオンライン注文システムを実装するには、JavaScript と WebSocket テクノロジを使用できます。 WebSocket は、TCP プロトコルをベースとした全二重通信プロトコルで、クライアントとサーバー間のリアルタイム双方向通信を実現します。リアルタイムオンラインオーダーシステムにおいて、ユーザーが料理を選択して注文するとき

WebSocket と JavaScript を使用してオンライン予約システムを実装する方法 今日のデジタル時代では、ますます多くの企業やサービスがオンライン予約機能を提供する必要があります。効率的かつリアルタイムのオンライン予約システムを実装することが重要です。この記事では、WebSocket と JavaScript を使用してオンライン予約システムを実装する方法と、具体的なコード例を紹介します。 1. WebSocket とは何ですか? WebSocket は、単一の TCP 接続における全二重方式です。

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

使用法: JavaScript では、insertBefore() メソッドを使用して、DOM ツリーに新しいノードを挿入します。このメソッドには、挿入される新しいノードと参照ノード (つまり、新しいノードが挿入されるノード) の 2 つのパラメータが必要です。

JavaScript は Web 開発で広く使用されているプログラミング言語であり、WebSocket はリアルタイム通信に使用されるネットワーク プロトコルです。 2 つの強力な機能を組み合わせることで、効率的なリアルタイム画像処理システムを構築できます。この記事では、JavaScript と WebSocket を使用してこのシステムを実装する方法と、具体的なコード例を紹介します。まず、リアルタイム画像処理システムの要件と目標を明確にする必要があります。リアルタイムの画像データを収集できるカメラ デバイスがあるとします。
