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

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



  #1  
ישן 25-11-2008, 08:26
  takachi1 takachi1 אינו מחובר  
 
חבר מתאריך: 25.11.08
הודעות: 1
בעיה בבדיקת תקינות סוגריים

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




קוד:
# include <iostream> #include <fstream> # include <cstring> # include <stl.h> using std::cout; using std::endl; int main () { vector<char> stack; int NumOfLine=0,flagEnd=0,i; ifstream OpenFile("compiler1.txt"); char line[160]; //a whole line will be stored here while((!OpenFile.eof())&&(line!=NULL)) { OpenFile.getline(line,160); //where 160 is the size of the array NumOfLine++; if (strlen(line)!=0) { cout<<"yes"<<endl; for (i=0;(i<strlen(line))&&(flagEnd==0);i++) { switch (line[i]) { case '(': stack.push_back(line[i]); break; case '[': stack.push_back(line[i]); break; case '{': stack.push_back(line[i]); break; case ')': if ((stack.empty())||(stack.back()!='(')) { cout<<NumOfLine<<endl; flagEnd=1; } if (stack.back()=='(') stack.pop_back(); break; case ']': if ((stack.empty())||(stack.back()!='[')) { cout<<NumOfLine<<endl; flagEnd=1; } if (stack.back()=='[') stack.pop_back(); break; case '}': if ((stack.empty())||(stack.back()!='{')) { cout<<NumOfLine<<endl; flagEnd=1; } if (stack.back()=='{') stack.pop_back(); break; } } if (!stack.empty()) cout<<NumOfLine<<endl; stack.clear(); line[0]='\0'; } } OpenFile.close(); return 0; }


הקלט הוא:
ציטוט:






1.if( Links[ToRemove.front()].first.empty() )





2.for(std::map<unsigned int,unsigned short int>::iterator erase1=Links[ToRemove.front()].second.begin();erase1!=Links[ToRemove.front()].second.end();++erase1){





3.new_end = remove ( Links[erase1->first].first.begin( ), Links[erase1->first].first.end( ),ToRemove.front());





4.Links[erase1->first].first.erase (new_end, Links[erase1->first].first.end( ) );





5.if(Links[erase1->first].first.empty())





6.ToRemove.push_back(erase1->first);





7.}









הספרות הם מהצד השני








נערך לאחרונה ע"י takachi1 בתאריך 25-11-2008 בשעה 08:32.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

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

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

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

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



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

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

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

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