Computer >> कंप्यूटर >  >> प्रोग्रामिंग >> C++

C++ में लिंक्ड सूचियों द्वारा दर्शाई गई दो संख्याओं को गुणा करें

इसमें अंकों के साथ दो लिंक्ड सूचियां दी गई हैं। हमें लिंक की गई सूची से बनी दो संख्याओं को गुणा करना होगा। इसे दो लिंक्ड सूचियों से संख्या बनाकर आसानी से किया जा सकता है। आइए एक उदाहरण देखें।

इनपुट

1 -> 2 -> NULL
2 -> 3 -> NULL

आउटपुट

2 -> 7 -> 6 -> NULL

एल्गोरिदम

  • दो लिंक की गई सूचियों को प्रारंभ करें।
  • दो संख्याओं को संग्रहीत करने के लिए 0 से दो चर प्रारंभ करें।
  • दो लिंक की गई सूचियों पर पुनरावृति करें।
    • अंत में प्रत्येक अंक को संबंधित संख्या चर में जोड़ें।
  • परिणामस्वरूप संख्याओं को गुणा करें और परिणाम को एक चर में संग्रहित करें।
  • परिणाम के साथ एक नई सूची बनाएं।
  • नई सूची प्रिंट करें।

कार्यान्वयन

C++ में उपरोक्त एल्गोरिथम का कार्यान्वयन निम्नलिखित है

#include <bits/stdc++.h>
using namespace std;
struct Node {
   int data;
   struct Node* next;
};
void addNewNode(struct Node** head, int new_data) {
   struct Node* newNode = new Node;
   newNode->data = new_data;
   newNode->next = *head;
   *head = newNode;
}
void multiplyTwoLinkedLists(struct Node* firstHead, struct Node* secondHead
, struct Node** newLinkedListHead) {
   int _1 = 0, _2 = 0;
   while (firstHead || secondHead) {
      if (firstHead) {
         _1 = _1 * 10 + firstHead->data;
         firstHead = firstHead->next;
      }
      if (secondHead) {
         _2 = _2 * 10 + secondHead->data;
         secondHead = secondHead->next;
      }
   }
   int result = _1 * _2;
   while (result) {
      addNewNode(newLinkedListHead, result % 10);
      result /= 10;
   }
}
void printLinkedList(struct Node *node) {
   while(node != NULL) {
      cout << node->data << "->";
      node = node->next;
   }
   cout << "NULL" << endl;
}
int main(void) {
   struct Node* firstHead = NULL;
   struct Node* secondHead = NULL;

addNewNode(&firstHead, 1);
   addNewNode(&firstHead, 2);
   addNewNode(&firstHead, 3);
   printLinkedList(firstHead);
   addNewNode(&secondHead, 1);
   addNewNode(&secondHead, 2);
   printLinkedList(secondHead);
   struct Node* newLinkedListHead = NULL;
   multiplyTwoLinkedLists(firstHead, secondHead, &newLinkedListHead);
   printLinkedList(newLinkedListHead);
  return 0;
}

आउटपुट

यदि आप उपरोक्त कोड चलाते हैं, तो आपको निम्न परिणाम प्राप्त होंगे।

3->2->1->NULL
2->1->NULL
6->7->4->1->NULL

  1. C++ में दो लिंक्ड सूचियों का प्रतिच्छेदन

    एक लिंक्ड सूची एक रैखिक डेटा संरचना है जिसमें प्रत्येक नोड में दो ब्लॉक होते हैं जैसे कि एक ब्लॉक में नोड का मान या डेटा होता है और दूसरे ब्लॉक में अगले फ़ील्ड का पता होता है। आइए मान लें कि हमारे पास एक लिंक्ड सूची है जैसे कि प्रत्येक नोड में एक यादृच्छिक सूचक होता है जो सूची में अन्य नोड्स को इंग

  1. सी++ में डबल लिंक्ड सर्कुलर सूचियां

    सर्कुलर लिंक्ड लिस्ट लिंक्ड लिस्ट का एक रूपांतर है जिसमें पहला तत्व अंतिम तत्व को इंगित करता है और अंतिम तत्व पहले तत्व को इंगित करता है। सिंगल लिंक्ड लिस्ट और डबल लिंक्ड लिस्ट दोनों को सर्कुलर लिंक्ड लिस्ट में बनाया जा सकता है। डबल लिंक्ड लिस्ट में, अंतिम नोड का अगला पॉइंटर पहले नोड को इंगित करता

  1. पायथन में लिंक्ड सूचियों के रूप में दर्शाई गई संख्याओं को खोजने का कार्यक्रम

    मान लीजिए कि हमारे पास दो एकल लिंक की गई सूची L1 और L2 है, जिनमें से प्रत्येक पहले कम से कम महत्वपूर्ण अंकों वाली संख्या का प्रतिनिधित्व करती है, हमें सारांशित लिंक्ड सूची ढूंढनी होगी। इसलिए, यदि इनपुट L1 =[5,6,4] L2 =[2,4,8] जैसा है, तो आउटपुट [7, 0, 3, 1, ] होगा। इसे हल करने के लिए, हम इन चरणों