In this HackerRank Vector-Erase in c++ programming language problem, You are provided with a vector of N integers. Then, you are given 2 queries. For the first query, you are provided with 1 integer, which denotes a position in the vector. The value at this position in the vector needs to be erased. The next query consists of 2 integers denoting a range of the positions in the vector. The elements which fall under that range should be removed. The second query is performed on the updated vector which we get after performing the first query.
HackerRank Vector Erase problem solution in c++ programming.
#include <cmath> #include <cstdio> #include <vector> #include <iostream> #include <algorithm> using namespace std; int main() { int size,pos,start,end,n,i,a,j; cin>>n; vector<int>v; for(i=0;i<n;i++) { cin>>a; v.push_back(a); } cin>>pos>>start>>end; v.erase(v.begin()+(pos-1)); v.erase(v.begin()+start-1,v.begin()+end-1); size=v.size(); cout<<size<<endl; for(j=0;j<size;j++) { cout<<v[j]<<" "; } return 0; }
Second solution
#include <cmath> #include <cstdio> #include <vector> #include <iostream> #include <algorithm> using namespace std; int main() { int N, a, x, b, c; vector<int> v; cin >> N; for (int i = 0; i < N; i++) { cin >> a; v.push_back(a); } cin >> x >> b >> c; v.erase(v.begin() + x - 1); v.erase(v.begin() + b - 1, v.begin() + c - 1); cout << v.size() << endl; for (int i = 0; i < v.size(); i++) { cout << v[i] << " "; } return 0; }