मान लीजिए कि हमारे पास किसी भी क्रम में उपयोगकर्ता नाम, ईमेल और फोन नंबर रखने वाले संपर्कों की एक सूची है, हमें वही संपर्क ढूंढना होगा (जब एक ही व्यक्ति के कई अलग-अलग संपर्क हों) और वही संपर्क वापस करें साथ में। हमें यह ध्यान रखना होगा कि -
-
एक संपर्क किसी भी क्रम के अनुसार उपयोगकर्ता नाम, ईमेल और फोन फ़ील्ड को स्टोर कर सकता है।
-
दो संपर्क समान हैं यदि उनके पास एक ही उपयोगकर्ता नाम या एक ही ईमेल या एक ही फोन नंबर है।
तो, यदि इनपुट जैसे संपर्क =[{"Amal", "[email protected]", "+915264"},{ "Bimal", "[email protected]", " +1234567"},{ "Amal123", "+1234567", "[email protected]"},{ "AmalAnother", "+962547", "[email protected]"}], तो आउटपुट होगा [ 0,2,3], [1] इंडेक्स [0,2,3] पर संपर्क समान हैं, और इंडेक्स 1 पर दूसरा संपर्क है।
इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
-
एक फ़ंक्शन को परिभाषित करें Generate_graph() । यह cnt, n, मैट्रिक्स लेगा
-
मेरे लिए 0 से n की सीमा में, करें
-
j के लिए 0 से n की सीमा में, करें
-
मैट्रिक्स [i, j] :=0
-
-
-
मेरे लिए 0 से n की सीमा में, करें
-
i + 1 से n की श्रेणी में j के लिए, करें
-
अगर cnt[i].slot1 cnt[j].slot1 या cnt[i].slot1 के समान है, cnt[j].slot2 orcnt[i].slot1 के समान है, तो cnt[j].slot3 या cnt[ के समान है। i].slot2 cnt[j].slot1 orcnt[i].slot2 के समान है, cnt[j].slot2 या cnt[i] के समान है। स्लॉट2 cnt[j].slot3 orcnt[i].slot3 के समान है। cnt[j].slot1 या cnt[i].slot3 के समान है, cnt[j].slot2 orcnt[i].slot3 के समान है, cnt[j].slot3 के समान है, फिर
-
मैट्रिक्स [i, j] :=1
-
मैट्रिक्स [जे, आई] :=1
-
लूप से बाहर आएं
-
-
-
-
एक फ़ंक्शन को परिभाषित करें visit_using_dfs() । यह ले जाएगा i, मैट्रिक्स, विज़िट किया गया, सोल, n
-
दौरा किया [i] :=सच
-
सोल के अंत में i डालें
-
j के लिए 0 से n की सीमा में, करें
-
यदि मैट्रिक्स [i] [j] गैर-शून्य है और विज़िट नहीं किया गया है [j] गैर-शून्य है, तो
-
visit_using_dfs(j, मैट्रिक्स, विज़िट किया गया, सोल, n)
-
-
-
मुख्य विधि से, निम्न कार्य करें -
-
n :=cnt का आकार
-
सोल:=एक नई सूची
-
मैट्रिक्स:=आकार n x n का एक वर्ग मैट्रिक्स बनाएं
-
विज़िट किया गया :=आकार n की एक सरणी बनाएं, और 0 से भरें
-
Generate_graph(cnt, n, मैट्रिक्स)
-
मेरे लिए 0 से n की सीमा में, करें
-
यदि विज़िट नहीं किया गया है [i] गैर-शून्य है, तो
-
visit_using_dfs(i, मैट्रिक्स, विज़िट किया गया, सोल, n)
-
सोल के अंत में -1 डालें
-
-
-
मैं के लिए 0 से सोल के आकार की सीमा में, ऐसा करें
-
अगर सोल [i] -1 के समान है, तो
-
अगली पंक्ति पर जाएँ
-
-
अन्यथा,
-
प्रदर्शन सोल[i]
-
-
उदाहरण
आइए बेहतर समझ पाने के लिए निम्नलिखित कार्यान्वयन देखें -
class contact: def __init__(self, slot1, slot2, slot3): self.slot1 = slot1 self.slot2 = slot2 self.slot3 = slot3 def generate_graph(cnt, n, matrix): for i in range(n): for j in range(n): matrix[i][j] = 0 for i in range(n): for j in range(i + 1, n): if (cnt[i].slot1 == cnt[j].slot1 or cnt[i].slot1 == cnt[j].slot2 or cnt[i].slot1 == cnt[j].slot3 or cnt[i].slot2 == cnt[j].slot1 or cnt[i].slot2 == cnt[j].slot2 or cnt[i].slot2 == cnt[j].slot3 or cnt[i].slot3 == cnt[j].slot1 or cnt[i].slot3 == cnt[j].slot2 or cnt[i].slot3 == cnt[j].slot3): matrix[i][j] = 1 matrix[j][i] = 1 break def visit_using_dfs(i, matrix, visited, sol, n): visited[i] = True sol.append(i) for j in range(n): if (matrix[i][j] and not visited[j]): visit_using_dfs(j, matrix, visited, sol, n) def get_similar_contacts(cnt): n = len(cnt) sol = [] matrix = [[None] * n for i in range(n)] visited = [0] * n generate_graph(cnt, n, matrix) for i in range(n): if (not visited[i]): visit_using_dfs(i, matrix, visited, sol, n) sol.append(-1) for i in range(len(sol)): if (sol[i] == -1): print() else: print(sol[i], end = " ") cnt = [contact("Amal", "[email protected]", "+915264"), contact("Bimal", "[email protected]", "+1234567"), contact("Amal123", "+915264", "[email protected]"), contact("AmalAnother", "+962547", "[email protected]")] get_similar_contacts(cnt)
इनपुट
cnt = [contact("Amal", "[email protected]", "+915264"), contact("Bimal", "[email protected]", "+1234567"), contact("Amal123", "+915264", "[email protected]"), contact("AmalAnother", "+962547", "[email protected]")]
आउटपुट
0 2 3 1