LISP Do function behaviour? -


मेरे पास यह सूची कोड ब्लॉक है।

  (defun test (y) (करू ( (एल एनआईएल (सेटिक वाई (आराम वाई)))) ((नल वाई) 1) (सेटिक एल (ऐपेंड एल '(1 1))) (प्रिंट एल)))  

और आउटपुट नीचे चित्रित किया गया है। किसी कारण के लिए यह वाई की स्थापना कर रहा है और फिर 'appending' (1 1)। क्या कोई इस व्यवहार को समझा सकता है?

यहां छवि विवरण दर्ज करें

एक do लूप की संरचना है:

  (करू ( (वैर इनिट-फॉर्म स्टेप-फॉर्म)) (समाप्ति-फार्म का नतीजा-फॉर्म) (बॉडी))  

मुझे लगता है कि जो कुछ आप खो रहे हैं वह यह है कि step-form हर चलन पर निष्पादित होता है और इस फ़ॉर्म के परिणाम चर पर सेट होता है तो setq में स्टेप-फ़ॉर्म में एक झंडा है, जो शायद आप जो इरादा रखते हैं वह नहीं कर रहे हैं।

इस प्रकार से लूप का क्रम (परीक्षण '(2 3 4)) है (प्रिंट छिपाना)

  - शून्य से प्रारंभ करने के लिए एल - चेक (शून्य y) जो y = (2 3 4) - (सेटिक एल (एपेंड एल '(1 1))) एल में अब मान है' (1 1) - चरण फॉर्म निष्पादित करें, यह सेट y = '(3 4) _and_ l =' (3 4) - (शून्य वाई) अभी भी गलत है - (सेटिक एल (एपेंड एल '(1 1))) सेट एल =' (3 4 1 1) - चरण फ़ॉर्म निष्पादित करें, y = '(4) _and_ l =' (4) - (सेटिक एल '(1 1))) सेट एल =' (4 1 1) - चरण फॉर्म निष्पादित करें, y = () तो लूप समाप्त होता है  

Comments

Popular posts from this blog

python - rpy2 import is not working -

javascript - How to get MySQL query result returned using $.ajax -

javascript - How to use the code plugin with popcornjs -