अजगर - पीछे की ओर

Backtracking पुनरावर्तन का एक रूप है। लेकिन इसमें किसी भी संभावनाओं में से केवल विकल्प चुनना शामिल है। हम एक विकल्प चुनते हैं और उससे पीछे हटते हैं, अगर हम एक ऐसी स्थिति में पहुँच जाते हैं जहाँ हम यह निष्कर्ष निकालते हैं कि यह विशिष्ट विकल्प आवश्यक समाधान नहीं देता है। जब तक हम वांछित समाधान प्राप्त नहीं करते तब तक हम प्रत्येक उपलब्ध विकल्प पर जाकर इन चरणों को दोहराते हैं।

नीचे दिए गए अक्षरों के सेट की व्यवस्था के सभी संभावित क्रम को खोजने का एक उदाहरण है। जब हम एक जोड़ी चुनते हैं तो हम यह सत्यापित करने के लिए बैकट्रैकिंग लगाते हैं कि क्या सही जोड़ी पहले से ही बनाई गई है या नहीं। यदि पहले से निर्मित नहीं है, तो जोड़ी को उत्तर सूची में जोड़ा जाता है, अन्यथा इसे अनदेखा किया जाता है।

def permute(list, s):
    if list == 1:
        return s
    else:
        return [ y + x
                 for y in permute(1, s)
                 for x in permute(list - 1, s)
                 ]

print(permute(1, ["a","b","c"]))
print(permute(2, ["a","b","c"]))

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

['a', 'b', 'c']
['aa', 'ab', 'ac', 'ba', 'bb', 'bc', 'ca', 'cb', 'cc']