Verifique se uma sequência é palíndromo em C
Eu tenho uma pergunta sobre esse código que estou escrevendo para um exercício. Eu tenho que verificar se uma string é palíndromo. Não consigo alterar a declaração da função. A função só retorna 1 quando todas as letras são iguais (como "aaaa"), mas se eu cobrar a frase com outro palíndromo (como "anna"), a função retornará 0, Eu não consigo descobrir por que esse appening.Thank você!
char* cargar (char*);
int pali (char*);
int main()
{
char*texto=NULL;
texto=cargar(texto);
int res=pali(texto);
if(res==1){printf("\nPalindrome");}
else printf("\nNot palindrome");
return 0;
}
char* cargar (char*texto)
{
char letra;
int i=0;
texto=malloc(sizeof(char));
letra=getche();
*(texto+i)=letra;
while(letra!='\r'){
i++;
texto=realloc(texto,(i+1)*sizeof(char));
letra=getche();
*(texto+i)=letra;}
*(texto+i)='\0';
return texto;
}
int pali (char* texto)
{
int i;
for(i=0;*(texto+i)!='\0';i++){
}i--;
if(i==0||i==1){return 1;}
if(*texto==*(texto+i)){
return pali(++texto);
}
else return 0;
}