検索
ホームページバックエンド開発PHPチュートリアルphp はボクシングの問題を解決します



ボクシング問題と石渡り問題に対する私の解決策
http://www.oschina.net/question/117304_112681 を参照してください

主な実装アイデアは次のとおりです:
1. 大きな石は最初に梱包する必要があります (早めにロードし、後で保留する) ) 後の項目はすべて梱包する必要があるので、最初に解決してください)
2. w に近い重量のアイテムを優先して梱包します。 9,5,1 の場合は 951 のパッキングが推奨されます
4. コードを簡素化するために PHP 関数を使用し、k 値に基づいて関数を生成する手法を使用します
5. このタイプの問題の性質上、計算は量が多い場合は、パラメータテストを適切に設定してください。

出力例: (rocks が 1~9、w が 15、k が 3 の場合)
3 つの要素から構成される最大解を求めます:
Array
(
[0] => 9
[1] => 5
[2] => 1
)

2 つの要素で構成される最大解を求めます:
Array
(
[0] => 9
[1] => 6
)

1 つの要素で構成される最大解を求めます解:
Array
(
[0] => 9
)

3つの要素から構成される最大解を見つけます:
Array
(
[0] => 8
[1] => 4
[2] => 3
)

2 つの要素で構成される最大解を求めます:
Array
(
[0] => 8
[1] => 7
)

1 つの要素で構成される最大解を求めます:
Array
(
[0] => 8
)

3 つの要素で構成される最大解を見つけます:
Array
(
[0] => 7
[1] => 6
[2] => 2
)

2 つの要素で構成される最大解:
Array
(
[0] => 7
[1] => 6
)

1 つの要素で構成される最大解を求めます:
Array
(
[0] => 7
) )

最小回数: 3
発送プロセス: Array
(
[0] => Array
(
[0] => 9
[1] => 5
[2] => 1
)

[1 ] => 配列
(
[0] => 8
[1] => 4
[2] => 3
)

[2] => 配列
(
[0] => 7
[1] => 6
[2] => 2
)

)
  1. // PHP演習ボクシング問題
  2. // 著者: mx (http://my.oschina.net/meikaiyuan)
  3. // 2013/5/30
  4. // 質問:
  5. / / http://www.oschina.net/question/117304_112681
  6. /*
  7. タイトル:
  8. 以前にも同様の質問をしたことがありますが、良い答えがありません。そこでもう一度聞きたいのです。
  9. 大小の石の山があり、ボートで川の反対側まで引っ張る必要があります
  10. -- m 個の石があり、それぞれの重さはわかっています
  11. -- ボートで運ぶことしかできません一度に k 個の石を積み込みます。積載重量は w
  12. を超えることはできません -- すべての石を川を渡って運ぶことができる最小往復回数を知りたいです。
  13. ------------------------------------
  14. 例 1
  15. 9 つの石があり、その重さは1,2,3,4,5,6,7,8,9
  16. k=3
  17. w=15
  18. 結果としては、少なくとも3回は発送できることになります。
  19. ------------------------------------
  20. 例 2
  21. 9 つの石があり、それぞれの重さは 1 です。 1,1,5,6,6,7,9,9
  22. k=3
  23. w=15
  24. その結果、出荷が完了するまでに少なくとも 4 回かかります。
  25. */
  26. //コードの始まり
  27. //Stones
  28. global $rocks;
  29. //船が一度に積み込める最大個数
  30. global $k;
  31. //船の最大積載量
  32. グローバル $w;
  33. $k =3;
  34. $rocks=array(1,2,3,4,5,6,7,8,9);
  35. // $rocks=array(1,1,1, 5,6,6,7, 9,9); //このデータセットに変更して結果を試してみますか?
  36. $w=15;
  37. // 現在何回出荷されていますか?
  38. $count=0;
  39. // 輸送プロセス、1=>array(9,5, の形の 2 次元配列) 1) 出荷された回数を示します 運が良かったでしょうか?
  40. $process=array();
  41. // 配列 $rocks 内で最大 $k 個の要素と次の合計が存在する組み合わせを見つけます。これらの要素は可能な限り大きく、指定された値 $w 以下です。配列は大きいものから小さいものに並べ替えられています
  42. function getMaxCombination( ) {
  43. //Stones
  44. global $rocks;
  45. //いくつ船は最大で何個まで運ぶことができますか? global $k;
  46. //船の最大積載量
  47. global $w;
  48. // すべての要素の合計が以下である最大のセットを保存しますw の中で最も大きい値です
  49. $k_w_result=array();
  50. // 組み合わせの最大値
  51. $max_sum=0;
  52. // どの項目が最大ですか
  53. $max_one=0 ;
  54. for ($start=$k; $start>0;$start--){
  55. // 固定の $start 要素で構成される最大解を求めます
  56. $start_w_arr = getMaxCombination2($start);
  57. echo "$start 要素で構成される最大解を求めます: n";
  58. print_r($start_w_arr);
  59. echo "n";
  60. $sum=array_sum( $start_w_arr );
  61. // 注: $k- - は降順に並べられているため、同じ和を持つ $k の組み合わせが早いほど、が見つかると、それが大きいほど、つまりより良い解となるため、
  62. if($sum>$max_sum){
  63. $max_sum=$sum;
  64. $max_one=$k 以下になります。 -$start;
  65. }
  66. $k_w_result[]= $start_w_arr ;
  67. }
  68. return $k_w_result[$max_one];
  69. }
  70. // 配列 $rocks 内の指定された $start 要素の組み合わせを見つけます。要素は可能な限り大きいですが、指定された値 $w 以下です。配列は大きい順に並べ替えられています
  71. function getMaxCombination2($start) {
  72. //rocks
  73. global $rocks;
  74. //船が一度に積み込める石の最大数 Block
  75. global $k;
  76. // 船の最大積載量
  77. global $w;
  78. if(count($rocks) return array(0);
  79. }
  80. $c=count($rocks );
  81. // ループ コードの $start 層を含む関数を $start に基づいて生成し、それをインクルードしてこの関数を呼び出します
  82. if(!file_exists ( "$start.php")){
  83. $output_1="";
  84. $output_2='$sum=';
  85. $output_3='if($sum $output_4='';
  86. for($i=0;$ i $output_1.='for($p'.$i.'='.$i.'; $p'.$i.' if($i> ;0){
  87. $output_2.='+';
  88. }
  89. $output_2.='$rocks[$p'.$i.']';
  90. $output_3.='$arr[]=$rocks[$ p'.$i.'];';
  91. $output_4.=' }';
  92. }
  93. $output_2.=';';
  94. $output_3.=' return $arr; }' ;
  95. $output='< ;?php 関数 myfor'.$start.'($rocks,$c ,$w){ '.$output_1.$output_2.$output_3.$output_4 .' } ?>';
  96. file_put_contents("$start .php",$output);
  97. include_once "$start.php";
  98. }
  99. else{
  100. include_once "$start.php";
  101. }
  102. return call_user_func('myfor'.$start ,$rocks,$c, $w);
  103. }
  104. //計算を開始します
  105. //最初に配列を大きいものから小さいものに並べ替えます。この操作は、後続のアルゴリズムで時間と労力を節約するための鍵です
  106. rsort($rocks);
  107. //石が大きすぎてボートが小さすぎる場合に、次のアルゴリズムが無限ループを引き起こすのを防ぎます
  108. foreach ($rocks as $v){
  109. if($v>$w){
  110. die("石を積んだ船で、また大きな船で戦いましょう!」 ");
  111. }
  112. }
  113. //アルゴリズム開始
  114. while(!empty($rocks)){
  115. // 船の積み込み開始
  116. $process[$count]=array();
  117. // 船の積み込み
  118. $process[$count]= getMaxCombination( ) ;
  119. // 出荷された
  120. をrocksから削除 foreach($process[$count] as $v){
  121. $key=array_search($v, $rocks) ;
  122. unset( $rocks[$key]);
  123. }
  124. $rocks=array_values($rocks);
  125. // 出荷数 + 1
  126. $count++;
  127. }
  128. // 出力結果
  129. echo '最小回数:' .$count. "n";
  130. echo '発送プロセス:';
  131. print_r($process);
  132. ?>
コードをコピー
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
11ベストPHP URLショートナースクリプト(無料およびプレミアム)11ベストPHP URLショートナースクリプト(無料およびプレミアム)Mar 03, 2025 am 10:49 AM

多くの場合、キーワードと追跡パラメーターで散らかった長いURLは、訪問者を阻止できます。 URL短縮スクリプトはソリューションを提供し、ソーシャルメディアやその他のプラットフォームに最適な簡潔なリンクを作成します。 これらのスクリプトは、個々のWebサイトにとって価値があります

Instagram APIの紹介Instagram APIの紹介Mar 02, 2025 am 09:32 AM

2012年のFacebookによる有名な買収に続いて、Instagramはサードパーティの使用のために2セットのAPIを採用しました。これらはInstagramグラフAPIとInstagram Basic Display APIです。

Laravelでフラッシュセッションデータを使用しますLaravelでフラッシュセッションデータを使用しますMar 12, 2025 pm 05:08 PM

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

LaravelのバックエンドでReactアプリを構築する:パート2、ReactLaravelのバックエンドでReactアプリを構築する:パート2、ReactMar 04, 2025 am 09:33 AM

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

Laravelテストでの簡略化されたHTTP応答のモッキングLaravelテストでの簡略化されたHTTP応答のモッキングMar 12, 2025 pm 05:09 PM

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

PHPのカール:REST APIでPHPカール拡張機能を使用する方法PHPのカール:REST APIでPHPカール拡張機能を使用する方法Mar 14, 2025 am 11:42 AM

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Codecanyonで12の最高のPHPチャットスクリプトCodecanyonで12の最高のPHPチャットスクリプトMar 13, 2025 pm 12:08 PM

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

2025 PHP状況調査の発表2025 PHP状況調査の発表Mar 03, 2025 pm 04:20 PM

2025 PHP Landscape Surveyは、現在のPHP開発動向を調査しています。 開発者や企業に洞察を提供することを目的とした、フレームワークの使用、展開方法、および課題を調査します。 この調査では、現代のPHP Versioの成長が予想されています

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。