RProgN , 142 बाइट्स, गैर-प्रतिस्पर्धात्मक
function tostack 'b' asoc stack 'a' asoc 0 'v' asoc b pop byte 'o' asoc b len while [ v o b pop byte ] 'o' asoc - + 'v' asoc b len end [ v end
गैर-प्रतिस्पर्धी, जैसा कि इस चुनौती की खोज के बाद 'टूस्टैक' कमांड को जोड़ा गया था (भले ही इसकी भयानक बाइट गिनती हो)
परीक्षण के मामलों
Hello, World!
-39
Cool, huh?
-4
व्याख्या
function # Push the function between this and end to the stack
tostack 'b' asoc # Convert the implicit input to a stack, associate it with 'b'
0 'v' asoc # Push 0 to the stack, associate it with 'v'
b pop byte 'o' asoc # Pop the top value of b (The end of the input), get the byte value, associate it with 'o'.
b len # Push the size of b to the stack
while [ # While the top of the stack is truthy, pop the top of the stack
v # Push v to the stack
o # Push o to the stack
b pop byte # Pop the top value of b, push the byte value of that to the stack
] 'o' asoc # Push a copy of the top of the stack, associate it with 'o'
- # Subtract the top of the stack from one underneith that, In this case, the old value of o and the byte.
+ # Sum the top of the stack and underneith that, that is, the difference of the old value and new, and the total value
'v' asoc # Associate it with 'v'
b len # Push the size of b to the stack (which acts as the conditional for the next itteration)
end [ # Pop the top of the stack, which will likely be the left over size of b
v # Push the value of v to the top of the stack
end # Implicitely returned / printed
RProgN एक गूढ़ भाषा है जिसे मैं रिवर्स पोलिश नोटेशन को ध्यान में रखकर काम कर रहा हूं। यह वर्तमान में बहुत ही क्रियात्मक है, इसमें चर असाइनमेंट 4 वर्णों का है, और इस तरह, हालांकि मैं भविष्य में थोड़ी सी शक्कर के साथ योजना बनाता हूं।
इसके अलावा, RProgN स्पष्ट रूप से स्टैक से तर्कों को एक्सेस करता है, और उन्हें उसी तरह वापस करता है। कार्यक्रम समाप्त होने के बाद स्टैक में छोड़ा गया कोई भी स्ट्रिंग डेटा, अंतर्निहित रूप से मुद्रित होता है।