डेटा संरचना - अभिव्यक्ति पार्सिंग

अंकगणितीय अभिव्यक्ति लिखने के तरीके को ए के रूप में जाना जाता है 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

सी प्रोग्रामिंग भाषा में कार्यान्वयन देखने के लिए, कृपया यहां क्लिक करें ।