इसमें कई शून्य के साथ दिया गया सरणी। हमें सरणी के सभी शून्यों को अंत तक ले जाना है। आइए एक उदाहरण देखें।
इनपुट
arr = [4, 5, 0, 3, 2, 0, 0, 0, 5, 0, 1]
आउटपुट
4 5 3 2 5 1 0 0 0 0 0
एल्गोरिदम
-
ऐरे को इनिशियलाइज़ करें।
-
किसी अनुक्रमणिका को 0. . पर प्रारंभ करें
-
दिए गए सरणी पर पुनरावृति करें।
-
यदि वर्तमान तत्व शून्य नहीं है, तो वर्तमान तत्व के साथ सूचकांक में मान को अपडेट करें।
-
सूचकांक बढ़ाएँ।
-
-
एक लूप लिखें जो उपरोक्त अनुक्रमणिका से n . पर पुनरावृत्त हो
-
सभी तत्वों को 0. . में अपडेट करें
-
कार्यान्वयन
C++ में उपरोक्त एल्गोरिथम का कार्यान्वयन निम्नलिखित है
#include <bits/stdc++.h> using namespace std; void moveZeroesToEnd(int arr[], int n) { int index = 0; for (int i = 0; i < n; i++) { if (arr[i] != 0) { arr[index++] = arr[i]; } } while (index < n) { arr[index++] = 0; } } int main() { int arr[] = {4, 5, 0, 3, 2, 0, 0, 0, 5, 0, 1}; int n = 11; moveZeroesToEnd(arr, n); for (int i = 0; i < n; i++) { cout << arr[i] << " "; } cout << endl; return 0; }
आउटपुट
यदि आप उपरोक्त कोड चलाते हैं, तो आपको निम्न परिणाम प्राप्त होंगे।
4 5 3 2 5 1 0 0 0 0 0