How to get all palindrome substrings in a string with C++

1 Answer

0 votes
#include <bits/stdc++.h> 

using namespace std;

bool is_palindrome(string s, int i, int j) {
    string rev = s.substr(i, j - i);
    reverse(rev.begin(), rev.end()); 

    string tmp_s = s.substr(i, j - i);
     
    bool b = false;
    if (tmp_s == rev && tmp_s.length() >= 2) {
        b = true;
    }

    return b;
}
 
int main() {
    string s = "abaab";
      
    for (int i = 0; i < s.length() - 1; i++) { 
        for (int j = i + 1; j <= s.length(); j++) { 
             if (is_palindrome(s, i, j)) {
                cout << s.substr(i, j - i) << endl;
             }
        }
    }
    
    return 0;
}
 
  
  
/*
run:
  
aba
baab
aa

*/

 



answered Oct 22, 2019 by avibootz

Related questions

1 answer 181 views
1 answer 163 views
1 answer 156 views
1 answer 235 views
1 answer 179 views
1 answer 180 views
1 answer 169 views
...