דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. מציאת סוגריים בתוך מערך

מציאת סוגריים בתוך מערך

מתוזמן נעוץ נעול הועבר תכנות
4 פוסטים 2 כותבים 173 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • ש מנותק
    ש מנותק
    ש.ב.ח.
    כתב ב נערך לאחרונה על ידי
    #1

    השאלה יותר בשביל לקבל עצה עם יש דרך טובה.

    יש לי מערך של אובייקטים שמקורו מניתוח משפט SQL
    לכל אובייקט יש את ערך הexpr שמכיל את הטקסט
    אני צריך למצוא קבוצות סוגריים בתוך ערכי הwhere

    השאילתה הגולמית היא (לדוגמא):

    WHERE a > b AND (a = 100 OR b < 3 OR (z > 10 AND y < 5))
    

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

    בשים לב על שיש סוגרים מקוננים.

    dovidD תגובה 1 תגובה אחרונה
    0
    • dovidD מנותק
      dovidD מנותק
      dovid ניהול
      השיב לש.ב.ח. ב נערך לאחרונה על ידי
      #2

      @ש-ב-ח אתה מכין שני מערכים, מערך א' אחד לשמור פתיחות סוגריים, ומערך ב' שמכיל צמדי פותח/סוגר.
      אתה צריך לעבור בלולאה על כל תו.
      על כל סימן סוגר פותח, אתה מוסיף למערך א' את האינדקס הנוכחי, ועל כל סימן סוגר מסיים אתה מסיר את הערך האחרון במערך א' ומעביר אותו יחד עם האינדקס הנוכחי למערך ב'.

      מנטור אישי למתכנתים (ולא רק) – להתקדם לשלב הבא!

      בכל נושא אפשר ליצור קשר dovid@tchumim.com

      dovidD תגובה 1 תגובה אחרונה
      2
      • dovidD מנותק
        dovidD מנותק
        dovid ניהול
        השיב לdovid ב נערך לאחרונה על ידי
        #3

        אני מאמין שמדובר בPHP, אני מספק לך את האלגוריתם מומחש בJS:

        function detectParantessPosition(input){
            const tuples = [];
            const lastOpened = [];
        
            for (let position = 0; position < input.length; position++) {
                let current = input[position];
                if(current == '(')
                    lastOpened.push(position);
                else if (current == ')')
                    tuples.push([lastOpened.pop(), position]);
            }
            return tuples;
        }
        
        const text = "WHERE a > b AND (a = 100 OR b < 3 OR (z > 10 AND y < 5))";
        const positions = detectParantessPosition(text);
        console.log(positions.map(x => text.substring(x[0]+1, x[1]-1)));
        
        

        מנטור אישי למתכנתים (ולא רק) – להתקדם לשלב הבא!

        בכל נושא אפשר ליצור קשר dovid@tchumim.com

        ש תגובה 1 תגובה אחרונה
        2
        • ש מנותק
          ש מנותק
          ש.ב.ח.
          השיב לdovid ב נערך לאחרונה על ידי ש.ב.ח.
          #4

          @dovid תודה רבה, אעבור על זה מחר.
          ואכן אני אמיר את זה לPHP.

          שוב תודה

          תגובה 1 תגובה אחרונה
          0

          בא תתחבר לדף היומי!
          • התחברות

          • אין לך חשבון עדיין? הרשמה

          • התחברו או הירשמו כדי לחפש.
          • פוסט ראשון
            פוסט אחרון
          0
          • דף הבית
          • קטגוריות
          • פוסטים אחרונים
          • משתמשים
          • חיפוש
          • חוקי הפורום