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 का मान सूची का हिस्सा नहीं है।