ให้เรตสมาชิก: 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
ฮิต
4354
ผู้สร้างเอกสาร
thatsawan
วันที่สร้างเอกสาร
2017-01-04 14:48:44

chapter_26.zip

ประเภทไฟล์ zip

ขนาดไฟล์ 1.28 KB

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

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




กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
อยากเป็นแฮกเกอร์
8
ชื่อ ต้า 23 ก.ย. 2017 6:38 pm
อยากเป็นแฮกเกอร์ แค่ไม่รู้อะไรเลย
12
ชื่อ ต้า 23 ก.ย. 2017 6:37 pm
ฉันมีความกังวนในความเป็นส่วนตัว
8
เฟสให้ยืนยันตัวตนด้วยรูปเพื่อนในเฟสแต่หนูจำไม่ได้จากนั้นก็เข้าไม่ได้เลยค๊ะ
13
โดย บุคคลทั่วไป 22 ก.ย. 2017 1:25 pm
สีผิวของ โปรแกรมเมอร์ และอาชีพต่างๆในฤดูร้อน
17
Before Dong 22 ก.ย. 2017 10:10 am
เรียกใช้คำสั่งในการวาดสี่เหลี่ยมและวงกลม
20
Ik Kat 21 ก.ย. 2017 7:28 pm
อยากรู้วิธีใส่ Google Structure ใน Joomla ว่าใส่ตำแหน่งไหนและแก้ตรงไหนบ้างครับ
13
Before Dong 21 ก.ย. 2017 2:20 pm
เมื่อ "ลูกค้า" บอกความต้องการของระบบ
24
Before Dong 21 ก.ย. 2017 10:29 am
oracle Sql loader
8
jataz2 20 ก.ย. 2017 5:13 pm
ประกันสังคมพร้อมก้าวสู่ Digital SSO ไม่ต้องพกบัตรรับรองสิทธิ ตั้งแต่วันที่ 1 ม.ค. 61 เป็นต้นไป
29
thatsawan 20 ก.ย. 2017 11:03 am
เมื่อคุณประชุมทีมแล้ว ทีมไม่เข้าใจที่คุณพูด
27
Before Dong 20 ก.ย. 2017 10:19 am
Joomla 3.8 มาแล้ว
17
mindphp 19 ก.ย. 2017 9:14 pm
สถานะสถานพยาบาลที่เข้าร่วมประกันสังคม 2560 อัพเดทล่าสุด
24
thatsawan 19 ก.ย. 2017 11:32 am
ทุกปัญหาใหญ่สำหรับ "User" เสมอ!!
26
Before Dong 19 ก.ย. 2017 10:16 am
เจอ Process ไม่พึงประสงค์ ผังและรัน ภายใต้ /tmp ป้องกันไม่ใช้ รันไฟล์ใน tmp
15
mindphp 19 ก.ย. 2017 7:52 am
ใครใช้ CCleaner เวอร์ชั่นเก่า อัพเกรดด่วน ให้ใหม่กว่า เวอร์ชัน 5.33
18
mindphp 19 ก.ย. 2017 5:29 am
facebook มันมันบังคับให้ตั้งชื่อใหม่ ให้เป็นชื่อจริงๆ
17
โดย บุคคลทั่วไป 19 ก.ย. 2017 5:18 am
สอบถามการประยุกต์ใช้คำสั่ง rect()
21
Ik Kat 18 ก.ย. 2017 6:00 pm
วิธีแก้ปัญหา Can't create/write to file '/tmp/#sql_6182_0.MAI' (Errcode: 2)
13
mindphp 18 ก.ย. 2017 3:40 pm
ทำ pop up ให้ login wordpress
32
โดย บุคคลทั่วไป 18 ก.ย. 2017 1:26 pm