|
|
|
ช่วยอธิบาย code จากกระทู้นี้ หน่อยครับ เรื่องการเรียงค่าใน array |
|
|
|
|
|
|
|
Code (PHP)
<?
$arr_num =array(23,11,24,35,46,68,43,52,73,82,91,25); // กลุ่มของ Array เริ่มนับเริ่มต้นคือ ตำแหน่งที่ 0
$count=count($arr_num); // นับจำนวน array ที่มีอยู่
for($i=0;$i<=$count;$i++){ //i=0 ; ถ้า i น้อยกว่าหรือเท่ากับจำนวน count ; เข้าเงื่อนไข i+1
echo $arr_num[$i]."<br>"; // Array[ตำแหน่งที่ i] . เว้นบรรทัด
}
?>
|
|
|
|
|
Date :
2013-05-17 11:17:36 |
By :
Ex-[S]i[L]e[N]t |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
มีต่อไหมครับ ตรง loop ถัดไปกับตรง if อ่ะครับ
|
|
|
|
|
Date :
2013-05-17 11:26:40 |
By :
oknaja |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Code (PHP)
<?
$arr_num =array(23,11,24,35,46,68,43,52,73,82,91,25); // กลุ่มของ Array เริ่มนับเริ่มต้นคือ ตำแหน่งที่ 0
$count=count($arr_num); // นับจำนวน array ที่มีอยู่
for($i=0;$i<=$count;$i++){ //i=0 ; ถ้า i น้อยกว่าหรือเท่ากับจำนวน count ; เข้าเงื่อนไข i+1
echo $arr_num[$i]; // Array[ตำแหน่งที่ i] . เว้นบรรทัด
if(($arr_num[$i]%2)==0){
echo "คู่";
}else{
echo "คี่";
}
}
?>
|
|
|
|
|
Date :
2013-05-17 11:50:13 |
By :
Ex-[S]i[L]e[N]t |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
เอ่อออ ที่ผมถามมันเป็นการเรียงจากน้อยไปมาก อ่ะครับ
|
|
|
|
|
Date :
2013-05-17 12:00:20 |
By :
oknaja |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-*-
คือสงสัยนะว่าทำไมไม่ใช้คำสั่ง sort ที่มีให้แล้ว
ถ้าจะเถียงว่าถ้าเป็นข้อมูลแบบอื่นล่ะก็ เค้ามีฟังก์ชันพวก uasort แล้วนะ
http://www.php.net/manual/en/function.uasort.php
แต่ก็จะนำเสนอการ sort แบบกากๆ ให้ละกัน
Code (PHP)
function quicksort($seq) {
if(!count($seq)) return $seq; //ถ้าตัวแปรแถวลำดับที่ให้มาว่าง ก็คืนค่าไป
$pivot= $seq[0];//กำหนดให้ตัวเปรียบเทียบเป็นตัวแปรในดัชนีแรกของตัวแปรแถวลำดับที่กำหนดให้
$low = $high = array(); //สร้างตัวแปรแถวลำดับสองตัวเพื่อการคืนค่า
$length = count($seq); //สร้างตัวแปรเก็บขนาดของตัวแปรแถวลำดับที่กำหนดให้ เพื่อเพิ่มประสิทธิภาพในการทำงานของชุดคำสั่งการทำหน้าที่ให้มากยิ่งขึ้น
for($i=1; $i < $length; $i++) { //สร้างการวนรอบจำนวน $lenght - 1 รอบ โดยเริ่มจากดัชนีที่ 1 (เนื่องจากดัชนีที่ 0 ถูกใช้ในการเปรียบเทียบไปแล้ว) เพื่อการท่องไปในตัวแปรแถวลำดับ
if($seq[$i] <= $pivot) { //ตรวจสอบว่าหากค่าในดัชนีนั้นๆ น้อยกว่าค่าเปรียบเทียบ
$low [] = $seq[$i]; //ทบค่าลงในดัชนีถัดไปของแถวลำดับค่าน้อยกว่า
} else { //ไม่เช่นนั้น
$high[] = $seq[$i]; //ทบค่าลงในดัชนีถัดไปของแถวลำดับค่ามากกว่า
}
}
return array_merge(quicksort($low), array($pivot), quicksort($high)); //คืนค่าของแถวลำดับที่ผสานแถวลำดับของแถวลำดับค่าน้อยกว่าที่จัดเรียงแล้ว ค่าเปรียบเทียบ และงแถวลำดับค่ามากกว่าที่จัดเรียงแล้ว
}
http://randymelder.com/test/quicksort.php
|
ประวัติการแก้ไข 2013-05-17 12:24:14
|
|
|
|
Date :
2013-05-17 12:21:46 |
By :
itpcc |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
จริงๆแล้วเป็นความโรคจิตของผมเองอ่ะครับ พอดีเปิดไปเจอละไม่เข้าใจ แต่ตอนนี้พอเข้าใจแล้ว ขอบคุณทุกท่านมากครับ
|
|
|
|
|
Date :
2013-05-17 13:44:26 |
By :
oknaja |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
เข้ามาขอบคุณเจ้าของกระทู้ ที่แปะลิงค์ https://www.thaicreate.com/php/forum/082516.html
ให้ได้เข้าไปอ่านเพิ่มรอยหยักของสมองของกระผมขึ้นอีกหลายหยัก ^___^
อ่านโค๊ดนานอยู่หลายนาที ไม่เข้าใจว่ามันทำงานยังไง
เลยนำตัวเลขมาแทนที่ตัวแปร
แล้วค่อยๆ รันไปอย่างช้าๆ บนกระดาษ A4 ที่ใช้แล้ว (ประหยัดทรัพยากรกันหน่อย ^^")
ก็พบว่าเป็นการนำตัวเลขมาสลับตำแหน่งกันนี่เอง
จับมาเปรียบเทียบโดยเริ่มจากด้านซ้ายก่อน ถ้าเลขไหนน้อยกว่าก็จับสลับไปด้านซ้าย
จนสุดท้ายจะได้เลขน้อยสุดอยู่ด้านซ้าย ไล่ไปหามากที่สุดอยู่ด้านขวา
บอกตามตรงว่าแว๊บแรกที่อ่าน ก็มองหาฟังก์ชั่น sort อาร์เรย์ทันที
เพราะคิดไม่ออกว่าจะเรียงมันยังไง (แสดงให้เห็นว่ารอยหยักในสมองน้อยลงไปทุกทีๆ T__T)
|
|
|
|
|
Date :
2013-05-17 14:14:29 |
By :
Naizan |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ท่าน Cyberman ทำเหมือนผมเลยครับ เอามาเขียนรันเลขในกระดาษ A4
|
|
|
|
|
Date :
2013-05-17 19:38:07 |
By :
oknaja |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Load balance : Server 04
|