c++stringrecursionpass-by-referencepass-by-pointer

removing x from a string using pass by pointer with recursion


I wrote this code to remove all occurrences of x from the string using recursion

#include <bits/stdc++.h>
using namespace std;
void removex(string str)
{
    if (str.length()==0)
    {
        return;
    }
    if (str[0] != 'x')
    {
         removex(str.substr(1,str.length()));
    }
    int i = 1;
    for (; str[i] != '\0'; i++)
    {
        str[i-1]=str[i];
    }
    str[i - 1] = str[i];
     removex(str);
    //  cout<<"strq"<<str<<endl;
}
int main()
{
    int t;
    cin >> t;
    while (t--)
    {
        string str;
        cin >> str;
        removex(str);
        cout << str << endl;
    }
    return 0;
} 

however it's pass by value and If I try using pass by reference it gives an error as initial value of reference to non-const must be an lvalueC. which means I need to make the reference constant which is not suitable for rest of the code. I tried pass by pointer and using arrow operator however unable to get value at index and not sure how to make recursion call. to pass address or ponter? can someone modify it accordingly?


Solution

  • Doing this with std::string and recursion is a formidable template for insanity. The erase/remove idiom exists for just this purpose, functions iteratively, and is highly efficient. Best of all, it already exists; all you have to do is set up the calls.

    That said, if you're bent on doing this recursively (and inefficiently) you need to convey the result back to the caller (including the recursive calls) somehow. The following does that using the function return type, which is std::string. This also uses the global free operator + that allows concatenation of a char + std::string to return a new string:

    #include <iostream>
    #include <string>
    
    std::string removex(std::string str)
    {
        if (!str.empty())
        {
            if (str[0] == 'x')
                str = removex(str.substr(1));
            else
                str = str[0] + removex(str.substr(1));
        }
        return str;
    }
    
    int main()
    {
        std::string str = "Remove all x chars from this string.";
        std::cout << "Before: " << str << '\n';
        std::cout << "After:  " << removex(str) << '\n';
        return 0;
    } 
    

    Output

    Before: Remove all x chars from this string.
    After:  Remove all  chars from this string.
    

    That said, that isn't the way I'd do this. I'd use the erase/remove idiom which would be much faster, and much more memory efficient.