डेटा संरचना - अभिव्यक्ति पार्सिंग
अंकगणितीय अभिव्यक्ति लिखने के तरीके को ए के रूप में जाना जाता है notation। एक अभिव्यक्ति के सार या आउटपुट को बदले बिना, अंकगणितीय अभिव्यक्ति को तीन अलग-अलग लेकिन समकक्ष संकेतन में लिखा जा सकता है। ये सूचनाएं हैं -
- Infix संकेतन
- उपसर्ग (पोलिश) संकेतन
- पोस्टफिक्स (रिवर्स-पोलिश) नोटेशन
इन सूचनाओं को नाम दिया गया है कि वे अभिव्यक्ति में ऑपरेटर का उपयोग कैसे करते हैं। हम यहाँ इस अध्याय में वही सीखेंगे।
Infix संकेतन
में हम अभिव्यक्ति लिखते हैं infix संकेतन, उदाहरण के लिए a - b + c, जहां ऑपरेटरों का उपयोग होता है in-बेटे का संचालन। हमारे लिए इंफ़िक्स अंकन में पढ़ना, लिखना और बोलना मनुष्य के लिए आसान है, लेकिन कंप्यूटिंग डिवाइस के साथ भी यह ठीक नहीं है। इन्फिक्स संकेतन की प्रक्रिया के लिए एक एल्गोरिथ्म समय और स्थान की खपत के मामले में मुश्किल और महंगा हो सकता है।
उपसर्ग सूचना
इस अंकन में, ऑपरेटर होता है prefixएड टू ऑपरेंड, यानी ऑपरेटर ऑपरेटर के आगे लिखा जाता है। उदाहरण के लिए,+ab। यह इसके infix नोटेशन के बराबर हैa + b। उपसर्ग संकेतन के रूप में भी जाना जाता हैPolish Notation।
उपसर्ग सूचना
इस अंकन शैली के रूप में जाना जाता है Reversed Polish Notation। इस अंकन शैली में, ऑपरेटर हैpostfixऑपरेंड्स को एड किया जाता है, ऑपरेटर ऑपरेटर के बाद लिखा जाता है। उदाहरण के लिए,ab+। यह इसके infix नोटेशन के बराबर हैa + b।
निम्नलिखित तालिका संक्षेप में तीनों अधिसूचनाओं में अंतर दिखाने की कोशिश करती है -
अनु क्रमांक। | Infix संकेतन | उपसर्ग सूचना | उपसर्ग सूचना |
---|---|---|---|
1 | ए + बी | + अब | ab + |
2 | (a + b) ∗ c | C + एबीसी | ab + c ∗ |
3 | एक + (बी + सी) | C ए + बी.सी. | abc + ∗ |
4 | ए / बी + सी / डी | + / एबी / सीडी | ab / cd / + |
5 | (a + b) ∗ (c + d) | C + अब + सीडी | ab + cd + ∗ |
6 | ((ए + बी)) सी) - डी | - - + एबीसी | अब + सी + डी - |
पार्सिंग एक्सप्रेशन
जैसा कि हमने चर्चा की है, यह एक बहुत ही प्रभावी तरीका नहीं है कि एल्गोरिथ्म या प्रोग्राम डिजाइन करने के लिए इन्फिक्स नोटेशन को पार्स करें। इसके बजाय, इन infix अंकन को पहले उपसर्ग या उपसर्ग संकेतन में परिवर्तित किया जाता है और फिर गणना की जाती है।
किसी भी अंकगणितीय अभिव्यक्ति को पार्स करने के लिए, हमें ऑपरेटर की पूर्ववर्तीता और सहानुभूति का भी ध्यान रखना होगा।
प्रधानता
जब एक ऑपरेंड दो अलग-अलग ऑपरेटरों के बीच होता है, तो कौन सा ऑपरेटर ऑपरेटर को पहले ले जाएगा, इसका फैसला दूसरों पर ऑपरेटर की पूर्वता से होता है। उदाहरण के लिए -
जैसा कि गुणन ऑपरेशन में इसके अलावा पूर्वता है, b * c का मूल्यांकन पहले किया जाएगा। ऑपरेटर पूर्वता की एक तालिका बाद में प्रदान की जाती है।
संबद्धता
एसोसिएटिविटी उस नियम का वर्णन करती है जहां एक ही पूर्वता वाले ऑपरेटर एक अभिव्यक्ति में दिखाई देते हैं। उदाहरण के लिए, अभिव्यक्ति में a + b - c, दोनों + और - की एक ही पूर्वता है, फिर अभिव्यक्ति के किस भाग का मूल्यांकन पहले किया जाएगा, यह उन ऑपरेटरों की सहानुभूति से निर्धारित होता है। यहां, दोनों + और - बाएं सहयोगी हैं, इसलिए अभिव्यक्ति का मूल्यांकन किया जाएगा(a + b) − c।
वरीयता और सहानुभूति एक अभिव्यक्ति के मूल्यांकन के क्रम को निर्धारित करती है। निम्नलिखित एक ऑपरेटर पूर्वता और संघात सारणी है (उच्चतम से निम्नतम) -
अनु क्रमांक। | ऑपरेटर | प्रधानता | संबद्धता |
---|---|---|---|
1 | घातांक ^ | उच्चतम | सही सहयोगी |
2 | गुणन (∗) और प्रभाग (/) | दूसरा सबसे ऊँचा | वाम सहयोगी |
3 | जोड़ (+) और घटाव (-) | सबसे कम | वाम सहयोगी |
उपरोक्त तालिका ऑपरेटरों के डिफ़ॉल्ट व्यवहार को दर्शाती है। अभिव्यक्ति के मूल्यांकन के किसी भी समय, कोष्ठक का उपयोग करके आदेश को बदला जा सकता है। उदाहरण के लिए -
में a + b*cअभिव्यक्ति भाग b*cपहले मूल्यांकन किया जाएगा, इसके अलावा गुणा के रूप में इसके अतिरिक्त। हम यहाँ के लिए कोष्ठक का उपयोग करते हैंa + b पहले मूल्यांकन किया जाना है, जैसे (a + b)*c।
उपसर्ग का मूल्यांकन एल्गोरिथम
अब हम उपसर्ग संकेतन का मूल्यांकन करने के लिए एल्गोरिथ्म को देखेंगे -
Step 1 − scan the expression from left to right
Step 2 − if it is an operand push it to stack
Step 3 − if it is an operator pull operand from stack and perform operation
Step 4 − store the output of step 3, back to stack
Step 5 − scan the expression until all operands are consumed
Step 6 − pop the stack and perform operation
सी प्रोग्रामिंग भाषा में कार्यान्वयन देखने के लिए, कृपया यहां क्लिक करें ।