ให้เรตสมาชิก: 3 / 5

ดาวใช้งานดาวใช้งานดาวใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

 บทที่ 26 การสร้างฟังก์ชันแบบเรียกตัวเอง (recursive function)

ตัวอย่าง การหาค่าแฟลทอเรียล n!
 
ไฟลตัวอย่าง :: code_ex1.php
<?php 
function factorial ($n) {
if ( ($n == 0) || ($n == 1) )
   return 1;
  else
    return $n*factorial($n-1);
}
echo  factorial(4);
?>

เงื่อนไขก็ใช้ฟังก์ชัน factorial() จากตัวอย่างข้างบน คือ $n จะต้องเป็นตัวแปรที่เก็บค่าที่เป็นเลขจำนวนเต็ม และไม่เป็นลบ ถ้าเราต้องการจะเขียนฟังก์ชันให้มีความปลอดภัยในการใช้งาน เราก็อาจจะเพิ่มเงื่อนไข เพื่อตรวจเช็คดูก่อนว่า ผู้ใช้ผ่านค่าของตัวแปรที่ตรงตามต้องการหรือไม่ เช่น ไม่ผ่านค่าที่เป็นสตริงค์ หรือเป็นเลขทศนิยม หรือค่าที่เป็นลบ เป็นต้น

ตัวอย่าง การค้นหาข้อมูลแบบ Binary Search ในอาร์เรย์ที่มีการเรียงข้อมูลจากน้อยไปมาก
 

ไฟลตัวอย่าง :: code_ex2.php
<?php
function randInt($low,$high) {
srand ( date("s") );
$range = $high - $low;
$num = (rand() % $range) + $low;
return $num;
}
function binSearch($key,$array,$left,$right)
{
$mid = ceil( ($left + $right) / 2 );
if ($left > $right)
return -1;
if ($array[$mid] == $key)
return $mid;
else if ($key < $array[$mid])
return binSearch($key,$array,$left,$mid-1);  // recursive call
else
return binSearch($key,$array,$mid+1,$right); // recursive call
}
$num=100;
$key = randInt(0,$num);
for($i=0; $i < $num; $i++) {
$sorted_array[$i] = $i+1;
} echo binSearch(13,$sorted_array,0,$num);
?>

ตัวอย่าง การสร้างสตริงค์แบบสุ่มอีกแบบหนึ่งซึ่งอาจจะนำไปใช้ในการสร้าง one-time password ( OTP)
 

ไฟลตัวอย่าง :: code_ex3.php
<?php
function randomToken($len) {
  srand( date("s") );
  $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
  $chars.= "1234567890!@#$%^&*()";
  $ret_str = "";
  $num = strlen($chars);
  for($i=0; $i < $len; $i++) {
    $ret_str.= $chars[rand()%$num];
  }
  return $ret_str;
}
echo randomToken(13)," ";
?>

หมายเหตุ: การกำหนดค่า seed สำหรับฟังก์ชัน srand() นอกจะใช้ date("s") เป็นตัวกำหนดค่าแล้ว เราอาจจะใช้ฟังก์ชันอื่นก็ได้ เช่น srand((double)microtime()*1000000);

หัวเรื่อง
บทที่ 26 การสร้างฟังก์ชันแบบเรียกตัวเอง (recursive function)
หมวดหมู่
PHP Basics, PHP Basics
ฮิต
15954
ผู้สร้างเอกสาร
thatsawan
วันที่สร้างเอกสาร
2017-01-04 14:48:44

chapter_26.zip

ประเภทไฟล์ zip

ขนาดไฟล์ 1.28 KB

ผู้อัพโหลดไฟล์ thatsawan

วันที่อัพโหลด 2014-04-21 15:22:50




กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
ชีวิตต้นเดือน ปลายเดือน
โดย จันนุสรณ์ ดีแก่ พฤ 21 ก.พ. 2019 6:52 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
9
พฤ 21 ก.พ. 2019 6:52 pm โดย จันนุสรณ์ ดีแก่
ขอโค้ดโปรแกรมโปรแกรมคำนวณเวลาที่ใช้ในการวิ่ง สำหรับ CodeBlockหน่อยครับ
โดย Anonymous พฤ 21 ก.พ. 2019 6:27 pm บอร์ด Programming - PHP
0
5
พฤ 21 ก.พ. 2019 6:27 pm โดย บุคคลทั่วไป
Features Review : Components MDBridge untuk menyambung data pengguna antara Joomla dan PHPbb Webboard
โดย abdkode พฤ 21 ก.พ. 2019 6:04 pm บอร์ด Bahasa Language
0
4
พฤ 21 ก.พ. 2019 6:04 pm โดย abdkode
Q - ปรับแก้โค้ดที่ Export ข้อมูลมาเป็น CSV อย่างไรค่ะ
โดย Parichat พฤ 21 ก.พ. 2019 5:01 pm บอร์ด Joomla Dev
0
1
พฤ 21 ก.พ. 2019 5:01 pm โดย Parichat
Q - ขอวิธีปรับแก้โค้ดที่ Export ข้อมูลมาเป็น Excel อย่างไรค่ะ
โดย Parichat พฤ 21 ก.พ. 2019 4:59 pm บอร์ด Joomla Dev
0
1
พฤ 21 ก.พ. 2019 4:59 pm โดย Parichat
Q - แก้ไขโค้ดที่ดึงข้อมูลมาเป็น PDF อย่างไรค่ะ
โดย Parichat พฤ 21 ก.พ. 2019 4:55 pm บอร์ด Joomla Dev
0
1
พฤ 21 ก.พ. 2019 4:55 pm โดย Parichat
Features Review : MDEvents untuk mengurus pelbagai jadual data aktiviti
โดย abdkode พฤ 21 ก.พ. 2019 4:51 pm บอร์ด Bahasa Language
0
6
พฤ 21 ก.พ. 2019 4:51 pm โดย abdkode
Features Review : Component MJUpgrade untuk menaik taraf Joomla 1.5 ke Joomla 2.5, 3.X
โดย abdkode พฤ 21 ก.พ. 2019 4:10 pm บอร์ด Bahasa Language
0
7
พฤ 21 ก.พ. 2019 4:10 pm โดย abdkode
Features Review : Mod Mslideshows untuk memaparkan gambar, video Youtube dari kandungan
โดย abdkode พฤ 21 ก.พ. 2019 3:29 pm บอร์ด Bahasa Language
0
3
พฤ 21 ก.พ. 2019 3:29 pm โดย abdkode
Plugin Editors XTD Multicontent 사용 지침과 설명
โดย wipaporn พฤ 21 ก.พ. 2019 12:28 pm บอร์ด korean Language - 한국어
0
6
พฤ 21 ก.พ. 2019 12:28 pm โดย wipaporn
Module M Slideshows 사용 지침과 설명
โดย wipaporn พฤ 21 ก.พ. 2019 12:27 pm บอร์ด korean Language - 한국어
0
6
พฤ 21 ก.พ. 2019 12:27 pm โดย wipaporn
Component M Multisite Master 사용 지침과 설명
โดย wipaporn พฤ 21 ก.พ. 2019 12:27 pm บอร์ด korean Language - 한국어
0
4
พฤ 21 ก.พ. 2019 12:27 pm โดย wipaporn
Component M Multisite Client 사용 지침과 설명
โดย wipaporn พฤ 21 ก.พ. 2019 12:27 pm บอร์ด korean Language - 한국어
0
4
พฤ 21 ก.พ. 2019 12:27 pm โดย wipaporn
MDFiles Featured 사용 지침과 설명
โดย wipaporn พฤ 21 ก.พ. 2019 12:26 pm บอร์ด korean Language - 한국어
0
4
พฤ 21 ก.พ. 2019 12:26 pm โดย wipaporn
Module MDFiles Popular 사용 지침과 설명
โดย wipaporn พฤ 21 ก.พ. 2019 12:25 pm บอร์ด korean Language - 한국어
0
11
พฤ 21 ก.พ. 2019 12:25 pm โดย wipaporn
Q - ต้องการซ่อนบ็อก Next step ในฟอร์มที่ยังกรอกข้อมูลยังไม่ครบทุกหน้า
โดย Parichat พฤ 21 ก.พ. 2019 11:54 am บอร์ด Joomla Dev
0
1
พฤ 21 ก.พ. 2019 11:54 am โดย Parichat
การล็อคหัวข้อ คืออะไร ทำความรู้จักกับเครื่องมือในการล็อคหัวข้อ สำหรับผู้ดูแลระบบ
โดย จันนุสรณ์ ดีแก่ พฤ 21 ก.พ. 2019 10:38 am บอร์ด phpBB user Guide Knowledge
0
5
พฤ 21 ก.พ. 2019 10:38 am โดย จันนุสรณ์ ดีแก่
งานประจำวันที่ 21 กุมภาพันธ์ 2562
โดย Four พฤ 21 ก.พ. 2019 10:23 am บอร์ด M077 - อิษยา งามสอาด
1
4
พฤ 21 ก.พ. 2019 9:40 pm โดย Four
งานประจำวันที่ 21 กุมภาพันธ์ 2562
โดย wipaporn พฤ 21 ก.พ. 2019 10:09 am บอร์ด MP10 - วิภาพร กะลาสี
1
3
พฤ 21 ก.พ. 2019 7:14 pm โดย wipaporn
ช่วยด้วยครับ Magento2 ขึ้นแบบนี้
โดย Wongsadudee Markii พ 20 ก.พ. 2019 11:20 pm บอร์ด Magento user Guide Knowledge
3
26
พฤ 21 ก.พ. 2019 4:46 am โดย mindphp