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

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



  #1  
ישן 03-04-2011, 20:09
  The_Equivocator The_Equivocator אינו מחובר  
 
חבר מתאריך: 11.02.04
הודעות: 16,543

מאוד פשוט:
ציטוט:
כתבו תוכנית שבונה מערך כזה (בעזרת קטע הקוד המצורף), ואז מאפשרת למשתמש לבדוק אם מספר מסויים מופיע בו. התוכנית תחפש כל מספר שהמשתמש יבקש, עד שהוא יקיש מספר שלא נמצא בטווח - מספר קטן מ-1 או מספר גדול מ-100. אם מספר מופיע - יודפס מספר התא בו הוא מופיע לראשונה, ואם לא - תודפס הודעה מתאימה.


נבנה מערך עזר בגודל 100 [ ]B(מאופס בתור התחלה), נעבור על המערך המקורי(מ1 עד 100) (נניח שמו [ ]A), ובכל פעם מבצעים השמה [ B[ i ]=A[ i;
ברור שבניה כזו עולה O(n).
לאחר שבצענו את בניית העזר תשובה לשאלה האם מספר X קיים במערך עולה בדיוק פעולה אחת.
פשוט בודקים האם 0=?[ B[ X , אם כן, אזי המספר אינו קיים, אחרת המספר קיים..

*כמובן שאת מערך העזר אפשר לבנות עוד בשלב הבניה הרנדומלית.. (ואז חסכנו את עלות הבניה..)

הנה
קוד:
int[] arr = new int[100]; int[] b = new int [100] for(int i=0; i<arr.length; i++){ arr[i] = (int) (1 + Math.random()*100); b[arr[i]] = arr[i]; } boolean find(int x){ if (x<1 || x >100) return false; return (b[x]!=0; }


אם רוצים את הדרישה הזו("יודפס מספר התא בו הוא מופיע לראשונה"), לא שמתי לב בהתחלה, אז פשוט אפשר ע"י שדרוג פשוט לתמוך גם בשאלתה מטופשת זו)

הנה זה עומד בדרישות..
קוד:
int[] arr = new int[100]; int[] b = new int [100] for(int i=0; i<arr.length; i++){ arr[i] = (int) (1 + Math.random()*100); if (b[arr[i]]==0) b[arr[i]]=arr[i]+i; } find(int x){ if (x<1 || x >100) System.out.println("No!"); else System.out.println("yes"+b[x]-x); }

נערך לאחרונה ע"י The_Equivocator בתאריך 03-04-2011 בשעה 20:31.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

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

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

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

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



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

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

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

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