इसमें कई शून्य के साथ दिया गया सरणी। हमें सरणी के सभी शून्यों को अंत तक ले जाना है। आइए एक उदाहरण देखें।
इनपुट
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