Pagini recente » Cod sursa (job #2312296) | Cod sursa (job #2554115) | Cod sursa (job #3276264) | Cod sursa (job #2505911) | Cod sursa (job #1985209)
#include <fstream>
#include <cstring>
using namespace std;
char v[501];
int pal(int st,int dr) {
while (st<dr) {
if (v[st]!=v[dr]) return 0;
++st;
--dr;
}
return 1;
}
int cresc(int st,int dr) {
int i,d=(dr+st)/2;
for (i=st+1;i<=d;++i)
if (v[i-1]>v[i]) return 0;
return 1;
}
int main()
{ int n,i,Max=0,j;
ifstream f("palm.in");
ofstream g("palm.out");
f.get(v,501);
n=strlen(v);
for (i=0;i<n;++i)
for (j=n-1;j>=i;--j)
if (pal(i,j) && cresc(i,j)) {
Max=max(Max,j-i+1);
break;
}
g<<Max;
return 0;
}