نشانهگذاری لهستانی
نشانهگذاری لهستانی (به انگلیسی: Polish notation) یا نشانهگذاری پیشوندی (به انگلیسی: prefix notation) یک نشانه گذاری برای منطق، علم حساب و ریاضیات است. ویژگی متمایزکننده اش این است که عملگرهارا سمت چپ عملوندها قرار میدهد اگر تعداد عملوندهای یک عملگر مقرر شد نتیجه نحو فاقد پرانتز یا دیگر براکتهایی که میتواند بدون ابهام تجزیه شود. منطق دان لهستانی Łukasiewicz این نشانه گذاری را در سال ۱۹۲۴ برای ساده کردن منطق گزاره ای ابداع کرد.
اصطلاح نشانه گذاری لهستانی برخی اوقات (به عنوان خلاف نشانه گذاری میانوندی) برای به حساب آوردن نشانه گذاری بسوندی لهستانی یا نشانه گذاری لهستانی برعکس که در ان عملگر بعد از عملوند قرار میگیرد.
هنگامی که نشانه گذاری لهستانی برای نحو استفاده میشود به وسیلهٔ مفسر زبانهای برنامهنویسی به درخت نحو انتزاعی تجزیه میشود و میتواند یک نمایش یک به یک تعریف شود. به همین دلیل Lisp و زبانهای برنامهنویسی مرتبط تمام نحوشان را نشان په گذاری پیشوندی تعریف میکنند.
یک نقل قول از Jan Łukasiewicz موجود است: >>به یک ایده از نشانه گذاری بدون پرانتز در سال ۱۹۲۴ دست یافتم، و آن را برای اولین بار در مقالهٔ خود استفاده کردم.
الونزو چرچ در کتاب قدیمی اش در منطق ریاضی به عنوان یک نشانه سزاوار حتی در برابر Whitehead و نشانه گذاری منطقی راسل به این نشانه گذاری اشاره میکند.
حساب
عبارت برای جمع دو عدد ۱و ۲ در نشانه گذاری پیشوندی به صورت "۲ ۱ + " به جای "۲ + ۱ " نوشته میشود در عبارات پیچیدهتر عملگرها همواره پشت عملوندها قرار دارند اما عملوندها ممکن است خود عبارات کوچکی باشند که عملگر دارند برای نمونه عبارتی که در نمایش میانوندی مرسوم است به صورت:
(5 − 6) * 7
میتواند به صورت پیشوندی به صورت زیر نوشته شود:
* (− 5 6) 7
از آنجا که عملگرهای محاسباتی ساده به صورت دودویی هستند (عملگر دودویی به عملگری میگویند که دو عملوند داشته باشد)، تمام نمایشهای پیشوندی آن بدون ابهام هستند و میتوان از قرار دادن پرانتزها صرف نظر کرد. به عنوان مثال، عبارت مثال قبل میتواند حتی به صورت سادهتر هم نوشته شود:
* − 5 6 7
برای تبدیل عبارات میانوندی به پیشوندی میتوان از یک پشته کمک گرفت.
برنامهنویسی کامپیوتری
نشانه گذاری prefix کاربرد گسترده ای در عبارتهای علامت دار Lisp دارد. درجایی که پرانتزها خواسته شدهاند هنگامی که عملگرها خود دادهاند!
توابع lisp ممکن است دارای تعداد ارگومانهای متغیر باشند.
زبان برنامهنویسی TCL، همانند Lisp، از نشانه گذاری لهستانی در کتابخانهٔ mathop استفاده میکند پ. زبان برنامهنویسی ambi از نشانه گذاری لهستانی برای اعمال حساب و برنامه سازی استفاده میکند.
نشانه گذاری پسوندی یا نشانه گذاری لهستانی برعکس در برخی از زبانهای برنامهنویسی پشته گرا مانند Forth استفاده میشود و قاعدهٔ عملی از نوع خاصی از ریاضیات است.
نحو CoffeeScript همچنین اجازه میدهد که توابع به وسیلهٔ نشانه گذاری لهستانی فراخوانده شوند و همچنین میتواند از نحو پیشوندی تکی که در بقیه زبانها رایج است استفاده کند.
تعداد مقدارهای بازگشتی از یک عبارت هم عرض است با تفاوت تعداد عملگر هاب درون عبارت و تعداد ارگومانهای هر عملگر منهای تعداد تمام مقدارهای بازگشتی از عملگرها.
ترتیب عملیات
ترتیب عملیات درون یک ساختمان نشانه گذاری پیشوندی تعریف میشود و به سادگی میتواند مشخص شود. یک چیز برای به خاطر سپاری این است که وقتی یک عمل اجرا میشود عملگر به وسیلهٔ عملگر بودن بر عملگر اول بکار برده میشود، این موضوع راجع به عملگرهایی که مبدل اند صادق نیست اما برای عملگرهای غیر مبدل مانند تقسیم و ضرب این قانون برای تحلیل و بررسی یک حکم قاطع است برای مثال حکم زیر:
/ 10 5 = 2
که "تقسیم ۱۰ بر ۵" خوانده میشود بنابراین پاسخ ۲ است نه ۱/۲
نشانه گذاری پیشوندی به خصوص با عملهای پشته گرا به توجه به قابلیت درونی برای تمایز سادهٔ ترتیب عملیات بدون نیاز به پرانتز است.
خواندن یک عبارت از چپ به راست، که ابتدا به دنبال یک عملگر میگردد و در نهایت به دنبال دو عملوند میگردد، اگر یک اپراتور قبل از این که عملوندها یاقت شوند پیدا شود عملوند قبلی کنار گذاشته میشود تا هنگامی که این عملگر مصمم شود، این پردازش تکرار میشود تا هنگامی که عملگر حل شود.
جستارهای وابسته
منابع
مشارکتکنندگان ویکیپدیا. «Polish notation». در دانشنامهٔ ویکیپدیای انگلیسی، بازبینیشده در ۱۴ ژوئیه ۲۰۱۳.