no it will take into account that lets say i have a string of ll, i will replace the 2nd occurrence of l with an x. It will take into account that every character that has a second occurrence in a row, it will replace that 2nd occurrence with an x.
lets say ll becomes lx, ww becomes wx. It is dependable on the first character.
> The first thing I saw right away is if((even=++even % 2) == 0
> That will result in undefined behavior.
Depends on a compiler switch. If C++11 mode is not enabled, it is undefined behaviour. Otherwise, it is well defined. In both, even = even++ % 2 results in undefined behaviour.
Just completely avoid this kind of stuff in the code that you write and/or use. Any code that requires interpretation by a language lawyer, when a simple transparent alternative is available, is badly written code.
//sorry didn't see that you meant only if its ll or ww then replace second char I thought you meant in general if you search for a character replace the second occurrence in the string
> It will take into account that every character that has a second occurrence in a row,
> it will replace that 2nd occurrence with an x.
> i would like to reverse the process now.
The function std::string replace_second_consecutive_char_with_x( std::string ) ;
is not injective, and therefore it is not invertible.
For instance, these two distinct members of its domain "Xerox xylophone boombox version xx meets Exxon minx 3" and "Xeroo ylophone boxmboo version x mexts Eexon minn 3"
would map to the same member of its co-domain. "Xerox xylophone boxmbox version xx mexts Exxon minx 3"
Just save a copy of the old string, and restore from the saved copy at a later time.