PALINDROME
Publicado por Thiago 07/04/2006
[ Hits: 11.890 ]
Este pequeno programa verifica se uma string de no máximo 50 caracteres é palíndrome ou não.
Palíndrome é a palavra que quando lida de frente para trás e de trás para frente tem a mesma senquência de caracteres.
Ex: ARARA
Sugestões serão bem vindas.
/**************************
Programa: palindrome.c
Autor: thiagoamm
Data: 02/04/06
***************************/
/* Bibliotecas */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* Cabecalho de funcoes e sub-rotinas */
void verifica(char *str, int tam, int *cond);
/* Funcao principal */
int main(void)
{
char string[50],continua;
int condicao,tamanho;
do
{
condicao = 1;
printf("\nInforme a palavra a ser verificada: ");
fflush(stdin);
fgets(string,50,stdin);
/* Tamanho da string meno o '{FONTE}' */
tamanho = strlen(string) - 1;
printf("\n --> Tamanho da string: %i\n",tamanho);
/* Invocando sub-rotina */
verifica(string,tamanho,&condicao);
if (condicao != 0)
printf("\n\n--> PALINDROME \n\n");
printf("\nDeseja continuar (s/n) ? ");
fflush(stdin);
continua = getchar();
} while (continua == 's' || continua == 'S');
printf("\n\n");
return(0);
}
/*
**********************
Sub-rotina verifica
**********************
Responsavel por verificar se uma string e palindrome.
Uma string e palindrome quando tem a mesma sequencia
de caracteres lida em ordem natural e em ordem inversa.
A logica desenvolvida consiste em dividir a string ao meio,
e utilizar dois contadores para indexa-la. O primeiro contador
percorre a string do inicio ate sua metade. O segundo contador
a percorre do fim ate sua metade. Sao comparadas as posicoes
indexadas pelo primeiro e segundo contador e caso alguma seja
diferente o laco (estrutura de repeticao) e imediatamente interrompido.
*/
void verifica(char *str, int tam,int *cond)
{
int i,j,metade_str;
j = tam - 1;
metade_str = (tam - 1) / 2;
for (i = 0; i <= metade_str; i++, j--)
{
/* Comparacao para strings de tres caracteres ou mais */
if (str[i] != str[j])
{
*cond = 0;
break;
}
}
}
aritmed1.c - Aritmetica de Ponteiros
Máximo Divisor Comum (algoritmo de Euclides)
Nenhum comentário foi encontrado.
Bluefin - A nova geração de ambientes de trabalho Linux
Como atualizar sua versão estável do Debian
Cirurgia para acelerar o openSUSE em HD externo via USB
Pós-instalação do elementary OS 8.1
Quer auto-organizar janelas (tiling) no seu Linux? Veja como no Plasma 6 e no Gnome
Copiando caminho atual do terminal direto para o clipboard do teclado
archlinux resolução abaixou após atualização (18)
Conky não mostra temperaturas da CPU no notebook (7)
Estou com um problema no meu desktop do ubuntu (2)
Não estou conseguindo fazer funcionar meu Postfix na versão 2.4 no Deb... (0)









