编程题
编写程序读一条消息, 然后检查这条消息是否是回文(消息中的字母从左往右看和从右往左看是一样的):
He lived as a devil, eh?
Madam, I am Adam.
忽略所有不是字母的字符。用指针方式进行操作。
main.c:负责测试
fun.c:负责判断
#include <stdio.h>
#include <string.h>
#include <ctype.h>
int fun(char ch_2[]);
int main()
{
while(1)
{
char ch_1[100];
int ret;
printf("请写一句话:\n");
fgets(ch_1,100,stdin);
// puts(ch_1);
int i, j;
for(i = 0, j = 0; i < strlen(ch_1); i++)
{
ch_1[i] = tolower(ch_1[i]);
if(isalpha(ch_1[i]) != 0 && isalpha(ch_1[j]) == 0){
ch_1[j] = ch_1[i];
ch_1[i] = ' ';
}
if(isalpha(ch_1[j]) != 0){
j++;
}
}
ch_1[j] = '\0';
// puts(ch_1);
ret=fun(ch_1);
if(ret==0)
printf("此句是回文句\n");
else
printf("此句不是回文句\n");
}
return 0;
}
int fun(char ch_2[])
{
char *p1=NULL,*p2=NULL;
int i=2;
p1=ch_2;
p2=&ch_2[strlen(ch_2)-1];
for(i=0;i<strlen(ch_2)/2;i++)
{
if(*(p1+i) != *(p2-i))
return 1;
}
return 0;
}
