#include <cstdio>
#include <iostream>
#include <vector>
#include <string>
using namespace std;
bool isOdd(int val) {
if (val & 1) return true; // bitwise checking
else return false;
}
int counts[1000]; // only 'a' - 'z' is significant
int main( ) {
//freopen("j.input.txt","r",stdin);
//freopen("j.analysis.txt","w",stdout);
int test, kase=1;
string inputstr;
cin >> test;
while (test--) {
cin >> inputstr;
int palindromes=0;
for (int i = 0 ; i<inputstr.size() ; i++) {
for (int ii = 'a' ; ii<='z' ; ii++) counts[ii] = 0;
int odds = 0;
for (int j=i ; j<inputstr.size() ; j++) {
counts[inputstr[j]]++;
if ( isOdd(counts[inputstr[j]]) ) odds++;
else odds--;
int rangeLength = j-i+1;
if ( isOdd(rangeLength) && odds==1 ) palindromes++;
if ( !isOdd(rangeLength) && odds==0 ) palindromes++;
}
}
cout << "Case " << kase++ << ": " << palindromes << endl;
}
return 0;
}
Monday, December 09, 2013
[UVa] 12718 - Dromicpalin Substrings
Subscribe to:
Post Comments (Atom)
Connect Rapoo MT750S with Linux (Tested on Manjaro)
I bought this obvious copy of MX Master 2S in hopes of having the device switching functionality along with a lightweight body because I ha...
-
I like coding a lot, keeps me glued to the PC for hours. For that reason it's a need to edit the Syntax Highlighter to suit my eyes for...
-
I bought this obvious copy of MX Master 2S in hopes of having the device switching functionality along with a lightweight body because I ha...
-
Method: The problem at first glance seems too straightforward but it's not that much. Think a bit about the lines "Erin can add ...
No comments:
Post a Comment
Post your comment here. If you want to say something about programming problems, scripts, software etc, please try to be as descriptive as possible.