


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

ホット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)

ホットトピック









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

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

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

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

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

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

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