#include #include #include using namespace std; string S; vector> substrings; int dp[5000]; int find(int now){ if(now >= (S.size() + 1) / 2){ return 1; }else if(dp[now] != -1){ return dp[now]; }else{ int ans = 0; for(int i = 0; i + now + 1 < (S.size() + 1) / 2; i++){ if(substrings[i][now] == substrings[i][S.size() - i - now - 1]){ ans += find(i + now + 1); ans %= int(1e9 + 7); } } return dp[now] = ans + 1; } } int main(){ cin >> S; for(int i = 0; i < S.size(); i++){ substrings.push_back({}); } for(int i = 0; i < S.size(); i++){ string substring = ""; for(int j = i; j < S.size(); j++){ substring.push_back(S[i]); substrings[substring.size() - 1].push_back(substring); } } for(int i = 0; i < 5000; i++){ dp[i] = -1; } cout << find(0) << endl; }