לוגו אתר Fresh          
 
 
  אפשרות תפריט  ראשי     אפשרות תפריט  צ'אט     אפשרות תפריט  מבזקים     אפשרות תפריט  צור קשר     חץ שמאלה ‎print ‎"Hello World!"; if‎ ‎not rules.‎know ‎then rules.‎read(); חץ ימינה  

לך אחורה   לובי הפורומים > מחשבים > תכנות ובניית אתרים
שמור לעצמך קישור לדף זה באתרי שמירת קישורים חברתיים
תגובה
 
כלי אשכול חפש באשכול זה



  #4  
ישן 24-12-2008, 00:23
צלמית המשתמש של Narxx
  משתמש זכר Narxx Narxx אינו מחובר  
 
חבר מתאריך: 21.12.04
הודעות: 30,021
בתגובה להודעה מספר 1 שנכתבה על ידי noamtzu שמתחילה ב "רקורסיה-חומר לימוד"

רקורסיה, בגדול, זו דרך שונה לבצע פקודות בלולאה עד תנאי עצירה מסויים.
לעיתים שימוש ברקורסיה הוא 'טבעי' יותר מאשר שימוש איטרטיבי (לולאות רגילות, while / for).

רקורסיה זו למעשה פונקציה שקוראת לעצמה, ואשר מקבלת פרמטרים עד אשר תנאי ידוע מתקיים.
דוגמא:
קוד:
double power(double x, int n) { if(n == 0) return 1.0; else return x * power( x , n - 1 ); }

בדוגמא הזו אתה יכול לראות שכדי לחשב את החזקה של מספר מסויים, אני שולח לפונקציה 2 פרמטרים, אשר אחד הוא הבסיס ואחד הוא החזקה.
בכל פעם שהפונקציה מופעלת, היא מקבלת את הבסיס שאינו משתנה ( x ) ואת החזקה הבאה שהיא צריכה לכפול בה, עד אשר החזקה המתקבלת - היא 0.
כאשר אנחנו מגיעים לחזקה 0, אנחנו יודעים שהתשובה היא 1 (כל מספר בחזקה 0 הוא המספר 1) ואת הערך הזה אנחנו מחזירים ברקורסיה בחזרה, מה שאומר שהערך הזה יוכפל ב x ושוב יחזור לפונקציה שקראה לו - עד אשר תגיע לפונקציה המקורית שתחזיר את התשובה ל main (או למי שלא קרא לפונקציה הזו).

מצטער אם זה נשמע מסובך, נסה להריץ כמה פעמים את זה בראש ואתה כבר תבין איך זה עובד (נניח ש x זה 4 ו- n הוא 3)... למי שרגיל לעבוד עם לולאות רגילות זה לוקח כמה שניות ככה לעשות סוויץ' בראש כדי להכנס לחשיבה של רקורסיה.
שורה תחתונה - זו פשוט לולאה עם תנאי עצירה
_____________________________________
בברכה, מתן.
www.MatanNarkiss.com

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

כלי אשכול חפש באשכול זה
חפש באשכול זה:

חיפוש מתקדם
מצבי תצוגה דרג אשכול זה
דרג אשכול זה:

מזער את תיבת המידע אפשרויות משלוח הודעות
אתה לא יכול לפתוח אשכולות חדשים
אתה לא יכול להגיב לאשכולות
אתה לא יכול לצרף קבצים
אתה לא יכול לערוך את ההודעות שלך

קוד vB פעיל
קוד [IMG] פעיל
קוד HTML כבוי
מעבר לפורום



כל הזמנים המוצגים בדף זה הם לפי איזור זמן GMT +2. השעה כעת היא 22:45

הדף נוצר ב 0.04 שניות עם 10 שאילתות

הפורום מבוסס על vBulletin, גירסא 3.0.6
כל הזכויות לתוכנת הפורומים שמורות © 2024 - 2000 לחברת Jelsoft Enterprises.
כל הזכויות שמורות ל Fresh.co.il ©

צור קשר | תקנון האתר