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

chapter_26.zip

ประเภทไฟล์ zip

ขนาดไฟล์ 1.28 KB

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

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




กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
การใช้งานโปรเเกรม Open ERP ในส่วนของ Fixed price (deposit) เงินที่จ่ายล่วงหน้า เป็นต้น
โดย สริญญา สมสา พ 24 เม.ย. 2019 6:33 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
4
พ 24 เม.ย. 2019 6:33 pm โดย สริญญา สมสา
B - สั่งสินค้ามากกว่า MOQ 100 ลัง แต่มีการแจ้งว่าไม่ถึง [2019-04][021]
โดย Parichat พ 24 เม.ย. 2019 6:22 pm บอร์ด Diageo - Web Ordering - Tester
0
1
พ 24 เม.ย. 2019 6:22 pm โดย Parichat
B - ข้อความแจ้งเตือนภาษาไทยเขียนไม่ถูกต้อง [2019-04][024]
โดย Parichat พ 24 เม.ย. 2019 6:13 pm บอร์ด Diageo - Web Ordering - Tester
0
2
พ 24 เม.ย. 2019 6:13 pm โดย Parichat
B - ข้อความแจ้งเตือนการสั่งสินค้านอกรอบเขียนไม่ถูกต้อง [2019-04][022]
โดย Parichat พ 24 เม.ย. 2019 6:10 pm บอร์ด Diageo - Web Ordering - Tester
0
3
พ 24 เม.ย. 2019 6:10 pm โดย Parichat
B - ข้อความแจ้งเตือนสั่งน้อยกว่า MOQ 100 ลัง แต่เขียนไม่ถูกต้อง [2019-04][023]
โดย Parichat พ 24 เม.ย. 2019 6:06 pm บอร์ด Diageo - Web Ordering - Tester
1
4
พ 24 เม.ย. 2019 6:10 pm โดย tsukasaz
การใช้งานโปรเเกรม Open ERP ในส่วน Some Order Lines การทำใบเเจ้งหนี้เเบบรายการ
โดย สริญญา สมสา พ 24 เม.ย. 2019 5:38 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
2
พ 24 เม.ย. 2019 5:38 pm โดย สริญญา สมสา
วิธีลัดแสกน QR Code ด้วย Google Assistant
โดย napharat079 พ 24 เม.ย. 2019 4:13 pm บอร์ด Share Knowledge
0
4
พ 24 เม.ย. 2019 4:13 pm โดย napharat079
กำหนดค่าไม่ให้ซ้ำยังไงค่ะ
โดย Kanyarat Kanthawong พ 24 เม.ย. 2019 3:27 pm บอร์ด SQL - Database
0
7
พ 24 เม.ย. 2019 3:27 pm โดย Kanyarat Kanthawong
วิธีตั้งค่า Gmail Offline เช็คเมล์ได้ไม่ต้องง้ออินเตอร์เน็ต
โดย napharat079 พ 24 เม.ย. 2019 3:00 pm บอร์ด Share Knowledge
0
7
พ 24 เม.ย. 2019 3:00 pm โดย napharat079
วีธีตั้งค่า Gmail ให้ตอบกลับอัตโนมัติ
โดย napharat079 พ 24 เม.ย. 2019 1:52 pm บอร์ด Share Knowledge
0
8
พ 24 เม.ย. 2019 1:52 pm โดย napharat079
B - CART and View Order คำนวณผิด [2019-04][020]
โดย Parichat พ 24 เม.ย. 2019 10:56 am บอร์ด Diageo - Web Ordering - Tester
2
4
พ 24 เม.ย. 2019 11:52 am โดย Parichat
งานประจำวันที่ 24 เมษายน 2562
โดย poumtip พ 24 เม.ย. 2019 10:12 am บอร์ด M080 - สุทธาทิพย์ อู่นาค
0
9
พ 24 เม.ย. 2019 10:12 am โดย poumtip
งานประจำวันที่ 24 เมษายน 2562
โดย napharat079 พ 24 เม.ย. 2019 10:03 am บอร์ด M079 - นภารัตน์ ฐิติกรโกวิท
0
1
พ 24 เม.ย. 2019 10:03 am โดย napharat079
เมธอด resize() ใน jQuery ใช้เมื่อหน้าต่างเบราว์เซอร์เปลี่ยนขนาด
โดย abdkode อ 23 เม.ย. 2019 7:00 pm บอร์ด Jquery & Ajax Knowledge
0
7
อ 23 เม.ย. 2019 7:00 pm โดย abdkode
วิธีตั้ง Vote ในแอปพลิเคชั่น Line
โดย napharat079 อ 23 เม.ย. 2019 5:10 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
10
อ 23 เม.ย. 2019 5:10 pm โดย napharat079
อยากทราบวิธีการเปิด การลบแบบไม่ถารวร ใน phpbb ครับ
โดย Ittichai_chupol อ 23 เม.ย. 2019 4:44 pm บอร์ด Programming - PHP
1
12
อ 23 เม.ย. 2019 6:08 pm โดย mindphp
ลบภาพพื้นหลังด่วนด้วยเทคโนโลยี AI
โดย napharat079 อ 23 เม.ย. 2019 3:30 pm บอร์ด Graphic design
0
18
อ 23 เม.ย. 2019 3:30 pm โดย napharat079
การใช้งานโปรเเกรม Open ERP ในส่วน Persentage นำสินค้ามาคิดเปอร์เซ็นต์
โดย สริญญา สมสา อ 23 เม.ย. 2019 3:01 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
23
อ 23 เม.ย. 2019 3:01 pm โดย สริญญา สมสา
R - รูปแบบเทมเพลตอีเมลทั้ง 3 รูปแบบ
โดย Parichat อ 23 เม.ย. 2019 1:49 pm บอร์ด Diageo - Web Ordering - Tester
4
15
พ 24 เม.ย. 2019 11:00 am โดย Parichat
R - ในไฟล์ Export to SAP ตัว H คือดึงข้อมูลลูกค้าที่สั่งซื้อมาแสดง และ D ดึงข้อมูลสินค้า
โดย Parichat อ 23 เม.ย. 2019 1:48 pm บอร์ด Diageo - Web Ordering - Tester
1
4
อ 23 เม.ย. 2019 6:35 pm โดย Parichat