Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,038

HOME > PHP > PHP Forum > อยากทราบการทำงานของโค๊ด dijkstra อยากวอนให้ผู้ที่รู้ช่วยอธิบายโค๊ดในส่วนที่มีให้หน่อยค่ะ ขอบพระคุณล่วงหน้าค่ะ



 

อยากทราบการทำงานของโค๊ด dijkstra อยากวอนให้ผู้ที่รู้ช่วยอธิบายโค๊ดในส่วนที่มีให้หน่อยค่ะ ขอบพระคุณล่วงหน้าค่ะ

 



Topic : 049289

Guest




อยากทราบการทำงานของโค๊ด dijkstra อยากวอนให้ผู้ที่รู้ช่วยอธิบายโค๊ดในส่วนที่มีให้หน่อยค่ะ ขอบพระคุณล่วงหน้าค่ะ


ส่วนของโค๊ด-------


Code (PHP)
<?PHP

class Dijkstra {

var $visited = array();
var $distance = array();
var $previousNode = array();
var $startnode =null;
var $map = array();
var $infiniteDistance = 0;
var $numberOfNodes = 0;
var $bestPath = 0;
var $matrixWidth = 0;

function Dijkstra(&$ourMap, $infiniteDistance) 
{
	$this -> infiniteDistance = $infiniteDistance;
	$this -> map = &$ourMap;
	$this -> numberOfNodes = count($ourMap);
	$this -> bestPath = 0;
}

function findShortestPath($start,$to = null)
{
	$this -> startnode = $start;
	for ($i=0;$i<$this -> numberOfNodes;$i++) 
	{
		if ($i == $this -> startnode) 
		{
			$this -> visited[$i] = true;
			$this -> distance[$i] = 0;
		} else {
				$this -> visited[$i] = false;
				$this -> distance[$i] = isset($this -> map[$this -> startnode][$i])
				? $this -> map[$this -> startnode][$i]
				: $this -> infiniteDistance;
				}
		$this -> previousNode[$i] = $this -> startnode;
	}

	$maxTries = $this -> numberOfNodes;
	$tries = 0;
	while (in_array(false,$this -> visited,true) && $tries <= $maxTries) 
	{
		$this -> bestPath = $this->findBestPath($this->distance,array_keys($this -> visited,false,true));
		if($to !== null && $this -> bestPath === $to) 
		{
			break;
		}
		$this -> updateDistanceAndPrevious($this -> bestPath);
		$this -> visited[$this -> bestPath] = true;
		$tries++;
	}
}

function findBestPath($ourDistance, $ourNodesLeft) 
{
	$bestPath = $this -> infiniteDistance;
	$bestNode = 0;
	for ($i = 0,$m=count($ourNodesLeft); $i < $m; $i++) 
	{
		if($ourDistance[$ourNodesLeft[$i]] < $bestPath) 
		{
			$bestPath = $ourDistance[$ourNodesLeft[$i]];
			$bestNode = $ourNodesLeft[$i];
		}
	}
	return $bestNode;
}

function updateDistanceAndPrevious($obp) 
{
	for ($i=0;$i<$this -> numberOfNodes;$i++) 
	{
		if( (isset($this->map[$obp][$i])) && (!($this->map[$obp][$i] == $this->infiniteDistance) || ($this->map[$obp][$i] == 0 )) && (($this->distance[$obp] + $this->map[$obp][$i]) < $this -> distance[$i]))
		{
			$this -> distance[$i] = $this -> distance[$obp] + $this -> map[$obp][$i];
			$this -> previousNode[$i] = $obp;
		}
	}
}

function printMap(&$map) 
{
	$placeholder = ' %' . strlen($this -> infiniteDistance) .'d';
	$foo = '';
	for($i=0,$im=count($map);$i<$im;$i++) 
	{
		for ($k=0,$m=$im;$k<$m;$k++) 
		{
			$foo.= sprintf($placeholder, isset($map[$i][$k]) ? $map[$i][$k] : $this -> infiniteDistance);
		}
	$foo.= "\n";
	}
	return $foo;
}

function getResults($to = null) 
{
	$ourShortestPath = array();
	$foo = '';
    for ($i = 0; $i < $this -> numberOfNodes; $i++) 

	{
		if($to !== null && $to !== $i) 
		{
			continue;
		}
		$ourShortestPath[$i] = array();
		$endNode = null;
		$currNode = $i;
		$ourShortestPath[$i][] = $i;
		while ($endNode === null || $endNode != $this -> startnode) 
		{
			$ourShortestPath[$i][] = $this -> previousNode[$currNode];
			$endNode = $this -> previousNode[$currNode];
			$currNode = $this -> previousNode[$currNode];
		}
		$ourShortestPath[$i] = array_reverse($ourShortestPath[$i]);
		if ($to === null || $to === $i) 
		{
			if($this -> distance[$i] >= $this -> infiniteDistance) 
			{
				$foo .= sprintf("ไม่่มีเส้น path จากจากโหนด %d ในรอบ•ี่ %d. \n",$this -> startnode,$i);
			} else {
					
					$foo .= sprintf($this -> distance[$i]);
				
					}
		
			if ($to === $i) 
			{
				break;
			}
		}
		
	}
	return $foo;
}
} 
?>



@ช่วยอธิบายเป็นขั้นตอนการทำงานอย่างละเอียดค่ะ พอดีว่ากำลังศึกษาเพื่อนำไปทำโปเจ็ค แต่ว่ายังไม่เข้าใจค่ะ รบกวนหน่อยนะคะ ด่วนค่ะ



Tag : PHP, CakePHP







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2010-09-24 17:53:12 By : ผู้เริ่มต้น View : 1069 Reply : 1
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

ลองอ่านก่อนน่ะครับ ไม่เข้าใจตรงไหนก็ค่อยถามน่ะครับ ความหมายของ function ลองเดาจาก ความหมายของคำศัพท์ครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2010-09-24 18:32:16 By : webmaster
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : อยากทราบการทำงานของโค๊ด dijkstra อยากวอนให้ผู้ที่รู้ช่วยอธิบายโค๊ดในส่วนที่มีให้หน่อยค่ะ ขอบพระคุณล่วงหน้าค่ะ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 05
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2025 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่