मारियोलैंग एक दो आयामी प्रोग्रामिंग भाषा है जहां स्रोत कोड एक सुपर मारियो ब्रदर्स स्तर जैसा दिखता है। इसके अलावा, इसका निर्देश सेट ब्रेनफक के समान है । इसका मतलब यह है कि मारियोलैंग अनिवार्य रूप से 2-डी ब्रेनफक है जहां अनुदेश सूचक मारियो की तरह चलता है। इसलिए जब मैंने प्रोग्रामिंग भाषा क्विज़ के लिए अपना मारियोलैंग सबमिशन लिखा , तो मैंने एक ब्रेनफ़क "हैलो, वर्ल्ड!" मारियोलैंग का कार्यक्रम। मैंने देखा कि यह एक बहुत ही व्यवस्थित प्रक्रिया के साथ संभव है, इसलिए आइए एक ब्रेनफक-टू-मारियोलैंग कंपाइलर लिखें!
नोट: मारियोलैंग कल्पना पूरी तरह से अस्पष्ट नहीं है, इसलिए मैं रूबी कार्यान्वयन की व्याख्या मान रहा हूं ।
मैं निम्नलिखित Brainfuck कार्यक्रम के साथ प्रक्रिया की व्याख्या करूँगा:
++[>+++++[>+++++++>++++++++++>+++>+<<<<-]<-]>>++.>+.+++++++..+++.>+++.>.
यह प्रिंट Hello!
और एक अनुगामी न्यूलाइन है।
क्रमशः कन्वर्ट
<
और>
टू ,(
और)
:++[)+++++[)+++++++)++++++++++)+++)+((((-](-]))++.)+.+++++++..+++.)+++.).
मारियो पर चलने के लिए एक मंजिल जोड़ें:
++[)+++++[)+++++++)++++++++++)+++)+((((-](-]))++.)+.+++++++..+++.)+++.). ========================================================================
अब मुद्दा यह है कि मारियोलैंग के पास लूप्स जैसे
[
और नहीं हैं]
। इसके बजाय, हमें मारियो को वास्तव में लूप में चलने के लिए लिफ्ट और दिशात्मक निर्देशों का उपयोग करना होगा। सबसे पहले, हम बदलने के[
साथ>
और फर्श को बदलने"
। और हम भी की जगह]
के साथ[!
और फर्श को बदलने=#
:++>)+++++>)+++++++)++++++++++)+++)+((((-[!(-[!))++.)+.+++++++..+++.)+++.). =="======"===============================#===#============================
(
"
और अंत#
से शुरू#
होने वाले"
) लिफ्ट का निर्माण कर सकते हैं, इसलिए अब हमें मारियो पर वापस चलने के लिए सहायक फर्श की आवश्यकता है। के साथ शुरू!
और अंत<
:++>)+++++>)+++++++)++++++++++)+++)+((((-[!(-[!))++.)+.+++++++..+++.)+++.). =="======"===============================#===#============================ ! < #===============================" ! < #=========================================="
ध्यान दें कि सभी लाइनें कम से कम तब तक होनी चाहिए जब तक कि सबसे बड़ा एनक्लोजिंग लूप न हो, क्योंकि दुभाषिया छोटी रेखाओं में लिफ्ट के सिरों को जोड़ने में सक्षम नहीं है। इसलिए, हम रिक्त स्थान के साथ मध्य रेखाओं को पैड करते हैं।
और बस। हमें एक पूरी तरह कार्यात्मक, समकक्ष मारियोलैंग कार्यक्रम मिला है।
चुनौती
एक मान्य ब्रेनफैक कार्यक्रम को देखते हुए, इसे मारियोलैंग कार्यक्रम में संकलित करने के लिए उपरोक्त प्रक्रिया को लागू करें।
आप मान सकते हैं कि इनपुट में केवल कमांड कैरेक्टर हैं, अर्थात कोई भी वर्ण नहीं है ,.+-<>[]
।
सभी सहायक मंजिल मुख्य कार्यक्रम मंजिल के लिए जितना संभव हो उतना करीब होना चाहिए। आप मध्यवर्ती मंजिलों की पंक्तियों को या तो जितना संभव हो उतना कम करने के लिए चुन सकते हैं (सबसे बड़े एन्कोडिंग लूप की चौड़ाई तक) या मुख्य कार्यक्रम के अंत तक।
आप STDIN (या निकटतम विकल्प), कमांड-लाइन तर्क या फ़ंक्शन तर्क के माध्यम से इनपुट ले रहे हैं और STDOUT (या निकटतम विकल्प), फ़ंक्शन रिटर्न मान या फ़ंक्शन (आउट) पैरामीटर के माध्यम से परिणाम लिख सकते हैं। यदि आप परिणाम को STDOUT में नहीं छापते हैं, तो यह अभी भी एक नई पंक्ति-अलग स्ट्रिंग होनी चाहिए।
यह कोड गोल्फ है, इसलिए सबसे छोटा उत्तर (बाइट्स में) जीतता है।
परीक्षण के मामलों
परीक्षण मामलों को निम्नानुसार स्वरूपित किया जाता है: पहली पंक्ति ब्रेनफक प्रोग्राम (आपका इनपुट) है, फिर एक खाली लाइन है, और अगली खाली लाइन तक सब कुछ मारियोलैंग में अपेक्षित आउटपुट है। ये उदाहरण गद्देदार स्थानों की न्यूनतम मात्रा का उपयोग करते हैं। वैकल्पिक रूप से, आप प्रत्येक पंक्ति को आउटपुट की पहली पंक्ति की चौड़ाई के लिए रिक्त स्थान के साथ पैड कर सकते हैं।
>,++-.<
),++-.(
=======
,[.,]
,>.,[!
="===#
! <
#==="
>>[-]<<[->>+<<]
))>-[!((>-))+(([!
=="==#=="=======#
! < ! <
#==" #======="
++[>+++++[>+++++++>++++++++++>+++>+<<<<-]<-]>>++.>+.+++++++..+++.>+++.>.
++>)+++++>)+++++++)++++++++++)+++)+((((-[!(-[!))++.)+.+++++++..+++.)+++.).
=="======"===============================#===#============================
! <
#==============================="
! <
#=========================================="
[][[[][[]]][]][[]]
>[!>>>[!>>[![![!>[![!>>[![!
"=#"""=#""=#=#=#"=#=#""=#=#
! < ! < ! < ! < ! <
#=" #=" #=" #=" #="
! < ! <
#====" #===="
! <
#=========="
! <
#================"
>>+++++++>>++>>++++>>+++++++>>+>>++++>>+>>+++>>+>>+++++>>+>>++>>+>>++++++>>++>>++++>>+++++++>>+>>+++++>>++>>+>>+>>++++>>+++++++>>+>>+++++>>+>>+>>+>>++++>>+++++++>>+>>+++++>>++++++++++++++>>+>>+>>++++>>+++++++>>+>>+++++>>++>>+>>+>>++++>>+++++++>>+>>+++++>>+++++++++++++++++++++++++++++>>+>>+>>++++>>+++++++>>+>>+++++>>++>>+>>+>>+++++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>++>>++++>>+++++++>>+>>+++++>>+++++++>>+>>+++++>>+>>+>>+>>++++>>+>>++>>+>>++++++>>+>>+++++>>+++++++>>+>>++++>>+>>+>>++>>+++++>>+>>+++>>+>>++++>>+>>++>>+>>++++++>>+>>+++++>>+++++++++++++++++++>>++>>++>>+++>>++>>+>>++>>++++>>+++++++>>++>>+++++>>++++++++++>>+>>++>>++++>>+>>++>>+>>++++++>>++++++>>+>>+>>+++++>>+>>++++++>>++>>+++++>>+++++++>>++>>++++>>+>>++++++[<<]>>[>++++++[-<<++++++++++>>]<<++..------------------->[-<.>>+<]>[-<+>]>]<<[-[-[-[-[-[-[>++>]<+++++++++++++++++++++++++++++>]<++>]<++++++++++++++>]<+>]<++>]<<[->.<]<<]
))+++++++))++))++++))+++++++))+))++++))+))+++))+))+++++))+))++))+))++++++))++))++++))+++++++))+))+++++))++))+))+))++++))+++++++))+))+++++))+))+))+))++++))+++++++))+))+++++))++++++++++++++))+))+))++++))+++++++))+))+++++))++))+))+))++++))+++++++))+))+++++))+++++++++++++++++++++++++++++))+))+))++++))+++++++))+))+++++))++))+))+))+++++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))++))++++))+++++++))+))+++++))+++++++))+))+++++))+))+))+))++++))+))++))+))++++++))+))+++++))+++++++))+))++++))+))+))++))+++++))+))+++))+))++++))+))++))+))++++++))+))+++++))+++++++++++++++++++))++))++))+++))++))+))++))++++))+++++++))++))+++++))++++++++++))+))++))++++))+))++))+))++++++))++++++))+))+))+++++))+))++++++))++))+++++))+++++++))++))++++))+))++++++>(([!))>)++++++>-((++++++++++))[!((++..-------------------)>-(.))+([!)>-(+)[!)[!((>->->->->->->)++)[!(+++++++++++++++++++++++++++++)[!(++)[!(++++++++++++++)[!(+)[!(++)[!((>-).([!(([!
========================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================="===#=="======="================#=========================="========#="=====#==#=="="="="="="="=====#================================#=====#=================#====#=====#=="=====#===#
! < ! < ! < ! < ! < ! <
#===" #================" #========" #=====" #=====" #====="
! < ! <
#=======================================================================" #========================================"
! <
#================================================"
! <
#===================================================================="
! <
#==========================================================================="
! <
#==================================================================================="
! <
#=================================================================================================="