ホームページ php教程 php手册 隣接行列 prim: PHP はグラフの隣接行列と Prim (prim アルゴリズム)、Floyd (floyd)、Dijkstra (ダイクストラ) アルゴリズムを実装します。

隣接行列 prim: PHP はグラフの隣接行列と Prim (prim アルゴリズム)、Floyd (floyd)、Dijkstra (ダイクストラ) アルゴリズムを実装します。

Jun 21, 2016 am 08:51 AM
gt private this


require 'mgraph.php';
$a = array('a', 'b', 'c', 'd', 'e', 'f' , ' g', 'h', 'i');
$b = array('ab'=>'10', 'af'=>'11', 'bg'=>'16 '、'fg'=>'17'、'bc'=>'18'、'bi'=>'12'、'ci'=>'8'、'cd'=>'22 '、'di'=>'21'、'dg'=>'24'、'gh'=>'19'、'dh'=>'16'、'de'=>'20 ', 'eh'=>'7','fe'=>'26');//キーはエッジ、値の重みです
$test = new mgraph($a, $b);
print_r ($test->prim());
?>
mgraph.php
/**
* php はグラフ隣接行列を実装します
*
* @author zhaojiangwei
* @since 2011/10/31 17:23
*/
class mgraph {
private $vexs; //頂点配列
private $arc; //エッジ隣接行列、つまり二次元配列
private $arcdata //エッジの配列情報
private; $direct; // グラフのタイプ (無向または有向)
private $haslist // 走査しようとするときの走査されたノードのストレージ
private $queue // 幅優先走査中に子ノードを格納するキュー; array
private $infinity = 65535; // 無限大、つまり 2 つの点の間に接続がないことを表します。この例には重み
private $primvexs がありません。 ; //プリムアルゴリズム中に頂点を保存
private $primarc //プリムアルゴリズム中にエッジを保存
public function mgraph($vexs, $arc, $direct = 0){
$ this->vexs = $vexs;
$this->arcdata = $arc;
$this->direct = $direct;
$this ->initalizearc();
$this->createarc();
}
プライベート関数 initalizearc(){
foreach($this->vexs as $value){
foreach($this->vexs as $cvalue){
$this->arc[$value][$cvalue] = ($value == $cvalue ? 0 : $this->infinity);
}
}
}
//グラフの作成 $direct: 0 は無向グラフを表し、1 は有向グラフを表します
private function createarc(){
foreach($this- >arcdata as $key=>$ value){
$strarr = str_split($key);
$first = $strarr[0];
$last = $strarr[1];
$this->arc[$ first][$last] = $value;
if(!$this->direct){
$this->arc[$last][$first] ] = $value;
}
}
}
//floyd アルゴリズム
public function floyd(){
$path = array();//パス配列
$ distance = array();// 距離 Array
foreach($this->arc as $key=>$value){
foreach($value as $k=>$v){
$path[$key][$ k] = $k;
$ distance[$key][$k] = $v;
}
}
for($j = 0 ; $j < count($this->vexs);{
for($i < count($this->vexs); $i ++) {
for($k = 0 ; $k vexs); $k ++){
if($ distance[$this->vexs[$i]] [$this->vexs[$k ]] > $ distance[$this->vexs[$i]][$this->vexs[$j]] + $ distance[$this->vexs [$j]][$this->vexs[$k]]){
$path[$this->vexs[$i]][$this->vexs[$k]] = $パス[$this->vexs[$ i]][$this->vexs[$j]];
$ distance[$this->vexs[$i]][$this->vexs [$k]] = $ distance[$ this->vexs[$i]][$this->vexs[$j]] + $ distance[$this->vexs[$j]][$this ->vexs[$k]];
}
}
}
}
return array($path, $ distance);
}
//djikstra アルゴリズム
public function dijkstra(){
$final = array();
$pre = array();//検索するノードの前のノード配列
$weight = array() ;//重みと配列
foreach($this->arc[$this->vexs[0]] as $k=>$v){
$final[$k] = 0;
$pre[$k ] = $this->vexs[0];
$weight[$k] = $v;
}
$final[$this->vexs[ 0]] = 1;
for($i = 0; $i vexs); $i ++){
$key = 0;
$min = $this->infinity;
for($j = 1; $j < count($this->vexs); $j ++){
$temp = $this->vexs[ $j];
if ($final[$temp] != 1 && $weight[$temp] < $min){
$key = $temp;
$min = $weight[$ temp];
}
}
$final[$key] = 1;
for($j = 0; $j < count($this->vexs); $j + +){
$temp = $this->vexs[$j];
if($final[$temp] != 1 && ($min + $this->arc[$key][ $temp]) < $weight [$temp]){
$pre[$temp] = $key;
$weight[$temp] = $min + $this->arc[$key] [$temp];
}
}
}
return $pre;
}
//kruscal アルゴリズム
プライベート関数 kruscal(){
$this- >krus = array();
foreach($this->vexs as $value){
$krus[$value] = 0;
}
foreach($this-> arc as $key=>$ value){
$begin = $this->findroot($key);
foreach($value as $k=>$v){
$end = $this->findroot( $k); この記事へのリンク http://www.cxybl.com/html/wlbc/Php/20120607/28507.html



このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Huawei GT3 ProとGT4の違いは何ですか? Huawei GT3 ProとGT4の違いは何ですか? Dec 29, 2023 pm 02:27 PM

多くのユーザーはスマートウォッチを選ぶときにファーウェイブランドを選択しますが、その中でもファーウェイ GT3pro と GT4 は非常に人気のある選択肢であり、多くのユーザーはファーウェイ GT3pro と GT4 の違いに興味を持っています。 Huawei GT3pro と GT4 の違いは何ですか? 1. 外観 GT4: 46mm と 41mm、材質はガラスミラー + ステンレススチールボディ + 高解像度ファイバーバックシェルです。 GT3pro: 46.6mm および 42.9mm、材質はサファイアガラス + チタンボディ/セラミックボディ + セラミックバックシェルです。 2. 健全な GT4: 最新の Huawei Truseen5.5+ アルゴリズムを使用すると、結果はより正確になります。 GT3pro: ECG 心電図と血管と安全性を追加

修正: Windows 11 で Snipping ツールが機能しない 修正: Windows 11 で Snipping ツールが機能しない Aug 24, 2023 am 09:48 AM

Windows 11 で Snipping Tool が機能しない理由 問題の根本原因を理解すると、適切な解決策を見つけるのに役立ちます。 Snipping Tool が正しく動作しない主な理由は次のとおりです。 フォーカス アシスタントがオンになっている: これにより、Snipping Tool が開かなくなります。破損したアプリケーション: 起動時にスニッピング ツールがクラッシュする場合は、破損している可能性があります。古いグラフィック ドライバー: 互換性のないドライバーは、スニッピング ツールに干渉する可能性があります。他のアプリケーションからの干渉: 実行中の他のアプリケーションが Snipping Tool と競合する可能性があります。証明書の有効期限が切れています: アップグレード プロセス中のエラーにより、この問題が発生する可能性があります。これらの簡単な解決策は、ほとんどのユーザーに適しており、特別な技術知識は必要ありません。 1. Windows および Microsoft Store アプリを更新する

Javaでプライベートとはどういう意味ですか Javaでプライベートとはどういう意味ですか Nov 24, 2022 pm 06:27 PM

Java では、プライベートは「プライベート」を意味し、クラス、プロパティ、メソッドを変更するために使用されるアクセス制御修飾子です。 private で変更されたクラス メンバーは、クラス自体のメソッドによってのみアクセスおよび変更でき、他のクラス (クラスのサブクラスを含む) からはアクセスおよび参照できません。したがって、private 修飾子は最高レベルの保護を持ちます。

iPhoneでApp Storeに接続できないエラーを修正する方法 iPhoneでApp Storeに接続できないエラーを修正する方法 Jul 29, 2023 am 08:22 AM

パート 1: 最初のトラブルシューティング手順 Apple のシステムステータスを確認する: 複雑な解決策を掘り下げる前に、基本から始めましょう。問題はデバイスにあるのではなく、Apple のサーバーがダウンしている可能性があります。 Apple のシステム ステータス ページにアクセスして、AppStore が適切に動作しているかどうかを確認してください。問題があれば、Apple が修正してくれるのを待つしかありません。インターネット接続を確認します。「AppStore に接続できません」問題は接続不良が原因である場合があるため、安定したインターネット接続があることを確認してください。 Wi-Fi とモバイル データを切り替えるか、ネットワーク設定をリセットしてみてください ([一般] > [リセット] > [ネットワーク設定のリセット] > [設定])。 iOS バージョンを更新します。

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

Java関数のプライベートアクセス修飾子の詳細な説明 Java関数のプライベートアクセス修飾子の詳細な説明 Apr 25, 2024 pm 04:48 PM

Private は、関数へのアクセスをその関数が定義されているクラスのみに制限する Java アクセス修飾子です。これには、他のクラスでは関数にアクセスできないことが含まれます。この関数はサブクラスでもアクセスできません。

この点を理解してフロントエンド担当者の7割をキャッチアップした記事 この点を理解してフロントエンド担当者の7割をキャッチアップした記事 Sep 06, 2022 pm 05:03 PM

同僚は、これによって指摘されたバグのために立ち往生しました。Vue2 のこの指摘の問題により、アロー関数が使用され、その結果、対応する props を取得できなくなりました。私がそれを彼に紹介したとき、彼はそれを知りませんでした。その後、私はわざとフロントエンド コミュニケーション グループに目を向けました。これまでのところ、フロントエンド プログラマーの少なくとも 70% はまだそれを理解していません。今日私はそれを共有しますyou this link. もしすべてが間違っている場合 まだ学習していない場合は、大きな口を与えてください。

watch4proとGTのどちらが優れていますか? watch4proとGTのどちらが優れていますか? Sep 26, 2023 pm 02:45 PM

Watch4proとgtはそれぞれ特徴や適用シーンが異なりますが、総合的な機能、高性能、スタイリッシュな外観を重視し、価格は高くてもいいという方にはWatch 4 Proの方が適しているかもしれません。高度な機能要件はなく、バッテリー寿命と手頃な価格を重視する場合は、GT シリーズの方が適しているかもしれません。最終的な選択は、個人のニーズ、予算、好みに基づいて決定する必要がありますが、購入する前に自分のニーズを慎重に検討し、さまざまな製品のレビューや比較を参照して、より情報に基づいた選択を行うことをお勧めします。

See all articles