MFC - लिंक्ड सूची
ए linked listएक रेखीय डेटा संरचना है जहाँ प्रत्येक तत्व एक अलग वस्तु है। सूची के प्रत्येक तत्व (हम इसे नोड कहेंगे) में दो आइटम शामिल हैं - डेटा और अगले नोड का संदर्भ। अंतिम नोड में शून्य का संदर्भ है।
एक लिंक की गई सूची एक डेटा संरचना है जिसमें नोड्स के समूह शामिल हैं जो एक अनुक्रम का प्रतिनिधित्व करते हैं। यह संरचनाओं के साथ डेटा स्टोर करने का एक तरीका है ताकि प्रोग्रामर जब भी आवश्यक हो डेटा को स्टोर करने के लिए स्वचालित रूप से एक नई जगह बना सके। इसकी कुछ मुख्य विशेषताएं हैं -
लिंक की गई सूची उन लिंक का एक क्रम है जिसमें आइटम शामिल हैं।
प्रत्येक लिंक में दूसरे लिंक का कनेक्शन होता है।
सूची में प्रत्येक आइटम को नोड कहा जाता है।
यदि सूची में कम से कम एक नोड है, तो एक नया नोड सूची में अंतिम तत्व के रूप में तैनात है।
यदि सूची में केवल एक नोड है, तो वह नोड पहले और अंतिम आइटम का प्रतिनिधित्व करता है।
लिंक सूची के दो प्रकार हैं -
सिंगली लिंक्ड लिस्ट
सिंगली लिंक्ड लिस्ट एक प्रकार का डेटा स्ट्रक्चर है। एक एकल लिंक की गई सूची में, सूची में प्रत्येक नोड नोड की सामग्री और एक पॉइंटर या संदर्भ को सूची में अगले नोड के लिए संग्रहीत करता है।
संदेह से जुड़ी सूची
एक दोहरी लिंक की गई सूची एक लिंक की गई डेटा संरचना है जिसमें क्रमिक रूप से लिंक किए गए रिकॉर्ड का एक सेट होता है जिसे नोड्स कहा जाता है। प्रत्येक नोड में दो फ़ील्ड होते हैं जो नोड के अनुक्रम में पिछले और अगले नोड के संदर्भ होते हैं।
CList वर्ग
MFC एक वर्ग प्रदान करता है CListजो एक टेम्प्लेट लिंक्ड सूची कार्यान्वयन है और पूरी तरह से काम करता है। सीएलस्ट सूचियाँ दोगुनी-जुड़ी सूचियों की तरह व्यवहार करती हैं। सूची का एक प्रकार सूची के लिए एक कुंजी है। क्रमिक रूप से किसी सूची को रखने के लिए और एक स्थान को धारण करने के लिए एक बुकमार्क के रूप में आप एक स्थिति के रूप में एक स्थिति चर का उपयोग कर सकते हैं।
अनु क्रमांक। | नाम और विवरण |
---|---|
1 | AddHead एक तत्व (या किसी अन्य सूची में सभी तत्व) को सूची के प्रमुख में जोड़ता है (एक नया सिर बनाता है)। |
2 | AddTail एक तत्व (या किसी अन्य सूची में सभी तत्व) को सूची की पूंछ में जोड़ता है (एक नई पूंछ बनाता है)। |
3 | Find सूचक मान द्वारा निर्दिष्ट तत्व की स्थिति प्राप्त करता है। |
4 | FindIndex शून्य-आधारित सूचकांक द्वारा निर्दिष्ट तत्व की स्थिति प्राप्त करता है। |
5 | GetAt किसी दिए गए स्थान पर तत्व प्राप्त करता है। |
6 | GetCount इस सूची में तत्वों की संख्या लौटाता है। |
7 | GetHead सूची का मुख्य तत्व लौटाता है (खाली नहीं हो सकता)। |
8 | GetHeadPosition सूची के प्रमुख तत्व की स्थिति लौटाता है। |
9 | GetNext पुनरावृति के लिए अगला तत्व प्राप्त करता है। |
10 | GetPrev पुनरावृत्ति के लिए पिछले तत्व प्राप्त करता है। |
1 1 | GetSize इस सूची में तत्वों की संख्या लौटाता है। |
12 | GetTail सूची का टेल एलिमेंट (खाली नहीं हो सकता)। |
13 | GetTailPosition सूची के पूंछ तत्व की स्थिति देता है। |
14 | InsertAfter किसी दिए गए स्थान के बाद एक नया तत्व सम्मिलित करता है। |
15 | InsertBefore किसी दिए गए पद से पहले एक नए तत्व को सम्मिलित करता है। |
16 | IsEmpty खाली सूची की स्थिति के लिए टेस्ट (कोई तत्व नहीं)। |
17 | RemoveAll इस सूची से सभी तत्वों को निकालता है। |
18 | RemoveAt इस सूची से एक तत्व निकालता है, स्थिति द्वारा निर्दिष्ट। |
19 | RemoveHead सूची के प्रमुख से तत्व निकालता है। |
20 | RemoveTail सूची की पूंछ से तत्व को निकालता है। |
21 | SetAt तत्व को दिए गए स्थान पर सेट करता है। |
CList वस्तुओं पर विभिन्न ऑपरेशन निम्नलिखित हैं -
सीएलस्ट ऑब्जेक्ट बनाएँ
CList मानों या वस्तुओं का संग्रह बनाने के लिए, आपको पहले संग्रह के मूल्यों का प्रकार तय करना होगा। आप मौजूदा आदिम डेटा प्रकारों में से एक जैसे कि int, CString, डबल आदि का उपयोग कर सकते हैं जैसा कि नीचे दिए गए कोड में दिखाया गया है।
CList<double, double>m_list;
सामगंरियां जोड़ें
किसी आइटम को जोड़ने के लिए, आप CList :: AddTail () फ़ंक्शन का उपयोग कर सकते हैं। यह सूची के अंत में एक आइटम जोड़ता है। सूची की शुरुआत में एक तत्व जोड़ने के लिए, आप CList :: AddHead () फ़ंक्शन का उपयोग कर सकते हैं। OnInitDialog () CList में, ऑब्जेक्ट बनाया जाता है और निम्न कोड में दिखाए गए अनुसार चार मान जोड़े जाते हैं।
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
आइटम पुनर्प्राप्त करें
सूची का एक प्रकार सूची के लिए एक कुंजी है। क्रमिक रूप से किसी सूची को ट्रेस करने के लिए आप इट्रेटर के रूप में एक स्थिति चर का उपयोग कर सकते हैं।
Step 1 - सूची से तत्व को पुनः प्राप्त करने के लिए, हम निम्नलिखित कोड का उपयोग कर सकते हैं जो सभी मूल्यों को पुनः प्राप्त करेगा।
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
Step 2 - यहाँ पूरा CMFCCListDemoDlg :: OnInitDialog () फ़ंक्शन है।
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
मध्य में आइटम जोड़ें
सूची के मध्य में आइटम जोड़ने के लिए, आप CList ::। InsertAfter () और CList :: InsertBeforefore () फ़ंक्शन का उपयोग कर सकते हैं। यह दो पैरामीटर्स लेता है - पहला, स्थिति (जहां इसे जोड़ा जा सकता है) और दूसरा, मान।
Step 1 - हमें एक नया आइटम डालें जैसा कि followng कोड में दिखाया गया है।
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
POSITION position = m_list.Find(85.26);
m_list.InsertBefore(position, 200.0);
m_list.InsertAfter(position, 300.0);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
Step 2 - अब आप देख सकते हैं कि हमने पहले मूल्य की स्थिति को पुनः प्राप्त किया 85.26 और फिर एक तत्व को उस मूल्य के पहले और एक तत्व डाला।
Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
अद्यतन आइटम मान
सरणी के मध्य में आइटम को अपडेट करने के लिए, आप CArray ::। SetAt () फ़ंक्शन का उपयोग कर सकते हैं। यह दो पैरामर्टर्स लेता है - पहला, स्थिति और दूसरा, मूल्य।
निम्नलिखित कोड में दिखाए अनुसार सूची में 300.00 से 400 अपडेट करते हैं।
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
POSITION position = m_list.Find(85.26);
m_list.InsertBefore(position, 200.0);
m_list.InsertAfter(position, 300.0);
position = m_list.Find(300.00);
m_list.SetAt(position, 400.00);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा। अब आप देख सकते हैं कि 300.00 का मान 400.00 में अपडेट किया गया है।
आइटम हटाएँ
किसी विशेष आइटम को हटाने के लिए, आप CList :: RemoveAt () फ़ंक्शन का उपयोग कर सकते हैं। सूची से सभी तत्व को हटाने के लिए, CList :: RemoveAll () फ़ंक्शन का उपयोग किया जा सकता है।
आइए हम उस तत्व को हटाते हैं, जिसका मूल्य 95.78 है।
BOOL CMFCCListDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
// TODO: Add extra initialization here
CList<double, double>m_list;
//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);
POSITION position = m_list.Find(85.26);
m_list.InsertBefore(position, 200.0);
m_list.InsertAfter(position, 300.0);
position = m_list.Find(300.00);
m_list.SetAt(position, 400.00);
position = m_list.Find(95.78);
m_list.RemoveAt(position);
//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) {
double nData = m_list.GetNext(pos);
CString strVal;
strVal.Format(L"%.2f\n", nData);
m_strText.Append(strVal);
}
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा। अब आप देख सकते हैं कि 95.78 का मान सूची का हिस्सा नहीं है।