עבור לתוכן
View in the app

A better way to browse. Learn more.

HWzone

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

[ג'אווה] - תרגיל ברקורסיה

Featured Replies

פורסם

הקדמה לשאלה:

מבוא:

בחלק זה אתם מתבקשים לכתוב פונקציות רקורסיביות להערכת ביטויים.

הגדרות:

• פעולה: אחת מפעולות החשבון +, - , *, %.

• מספר: סיפרה שלמה בין 0 ל- 9.

• ביטוי הינו מספר, או הרכבה של שני ביטויים עם פעולה ביניהם וסוגריים מסביב.

דוגמה לביטויים תקינים:

1, (5+4), (4*((4%3)+2)), ((3+1)*(9-2))

דוגמה לביטויים לא תקינים:

-1, 4+3, (21+3), 78, ((2+1))

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

האינדקס של הפעולה הראשית בביטוי (5+4) הוא 2,

האינדקס של הפעולה הראשית בביטוי (4*((4%3)+2)) הוא 2,

האינדקס של הפעולה הראשית בביטוי ((3+1)*(9-2)) הוא 6.

public static int find(String expr){

int num = 0;

int ans = -1;

for (int i=0; i<expr.length(); i++){

char c = expr.charAt(i);

if (c=='(') num++;

if (c==')') num--;

if ((c=='+' || c=='-' || c=='*' || c=='%')&& num==1) ans=i;

}

return ans;

}

כמו כן שימו לב לפעולות הבאות על תווים:

int valc = -1;

char c = '6';

if(c>='0' && c<='9') valc = c-'0';

System.out.println("valc = "+valc);

Output: valc = 6

השאלה:

כתבו את המחלקה Ex22 המכילה את הפונקציוה הבאה:

public static int evalExpr1(String expr){. . .}

הפונקציה מקבלת מחרוזת המייצגת ביטוי חוקי (יש להניח קלט תקין) ומחזירה את ערכו.

דוגמה: evalExpr1("(4+5)") תחזיר 9.

פורסם

מה השאלה שלך? אתה רוצה שנפתור את התרגיל? אם כן, זה לא המקום. תאמר מה ניסית לעשות וננסה להפנות אותך בכיוון הנכון.

ארכיון

דיון זה הועבר לארכיון ולא ניתן להוסיף בו תגובות חדשות.

דיונים חדשים

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.