当前位置:首页 » 编程语言 » c语言回文串

c语言回文串

发布时间: 2025-01-20 22:43:09

⑴ C语言判断回文串

下面介绍了几种判断回文的方法:
你提问的第一个地方,比如你输入了个5个字符的字符串 ,abcba 先判断第一个和最后一个是否相同 ,再判断第二个和倒数第二个 。
如果相等程序正常执行 ,如果不相等 ,break就跳出循环 ,你提问的第二个地方就是i 如果等于 len/2说明 上边循环式正常退出 。那就是说前后一一对比都相同 ,是回文数 ,不等于len/2说明是由break退出导致,既前边和后边某一位不相同
若输入 abbci=0str[0]='a' str[4-1-0]='c' 执行break;跳出for循环循环结束 i=0 所以判断不是回文若输入ab=0str[0]='a' str[4-1-0]='a' i=1str[1]='b' str[4-1-1]='b'i=2for循环条件不满足i
这还有另外一种方法,即include "stdio.h" main() { char str[50]; int p,i,j; printf("Input:"); scanf("%s",str); printf("Input the string is:%s\n",str); p=strlen(str); for(i=0,j=p-1;i=j) printf("huiwen"); else printf("not a huiwen"); }

⑵ 用递归判断字符串是否为回文串(C语言) 用递归判断字符串是否为回文串(C语言)

#include <stdio.h>
#define SIZE 50
int isPalindrome(char str[]);
int elementSize=0;
static int i=0;
int main()
{
int j=0,result;
char element,str[SIZE];
printf("请输入字符串,以回车结束:\n");
/*以下用循环结构读入字符数组的元素,防止了因字符串中含有空格而不能全部读入的情况*/
scanf("%c",&element);
while(element!='\n')
{
str[j]=element;
elementSize++;//记录了数组中已有元素的个数
j++;
scanf("%c",&element);
}

if(isPalindrome(str))
printf("该字符串是回文字符串\n");
else
printf("该字符串不是回文字符串\n");

// system("pause");
return 0;
}
/*函数功能:判断字符串是否为回文串*/
int isPalindrome(char str[])
{
/*把数组元素前后对应比较,即第一个元素与最后一个元素比较是否相等,依此类推*/
if(i>=elementSize-i-1)//说明是回文串
return 1;

else if(str[i]==str[elementSize-i-1])
{
i++;//i为全局静态变量
isPalindrome(str);
}

else //出现不相等的情况,说明不是回文串,返回0
return 0;
}

热点内容
买服务器如何砍价 发布:2025-09-15 21:04:27 浏览:820
我的世界直连服务器的区别 发布:2025-09-15 20:59:12 浏览:62
哈夫曼树构造算法 发布:2025-09-15 17:18:48 浏览:133
c语言函数要素 发布:2025-09-15 16:39:10 浏览:443
java读ftp文件 发布:2025-09-15 16:15:45 浏览:438
sql随机函数 发布:2025-09-15 15:20:19 浏览:107
校园服务器禁止设置ip 发布:2025-09-15 15:11:06 浏览:784
android刷回 发布:2025-09-15 14:54:24 浏览:591
n后问题算法 发布:2025-09-15 14:38:17 浏览:401
压缩机绝缘 发布:2025-09-15 14:31:10 浏览:550