| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1623 人关注过本帖
标题:[求助]判断字符串是否回文,不知道我哪里写错了
只看楼主 加入收藏
heecn
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-6-30
收藏
 问题点数:0 回复次数:10 
[求助]判断字符串是否回文,不知道我哪里写错了

#include<stdio.h>
#include<string.h>
int palindrome(char *string)
{
char *p,*q,*str="";
for(p=string;*p!='\0';p++);
p--;
for(q=str;(p+1)!=string;)
*q++=*p--;
*q='\0';
if(strcmp(str,string)==0) return 1;
else return 0;

}
void main()
{
char *str="aabaa";
palindrome(str);
}

搜索更多相关主题的帖子: 回文 字符 判断 
2007-05-06 21:43
mp3aaa
Rank: 5Rank: 5
等 级:贵宾
威 望:17
帖 子:2013
专家分:8
注 册:2006-2-15
收藏
得分:0 

怎么麻烦。。。。。。重新想个思路 在重新些一个把


羊肉串 葡萄干 哈密瓜!!
2007-05-06 21:48
jxw221
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2006-7-25
收藏
得分:0 
我见过类似的东西
你应该用递推 那样比较好解决这个问题
其实他知识个很基础的问题
2007-05-06 23:04
I喜欢c
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:64
帖 子:1749
专家分:0
注 册:2007-3-2
收藏
得分:0 
for(p=string;*p!='\0';p++);
p--;
可该为 p=string;p+=(strlen(string)-1);

 我是指针,却丢失了目标地址!          我是循环,却缺少了结束条件!      我是函数,却没有人来调用!   
2007-05-07 11:06
I喜欢c
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:64
帖 子:1749
专家分:0
注 册:2007-3-2
收藏
得分:0 

你就判断第一个个最后一个是否一样
一样继续判断第二个和倒数第二个...
不一样就不是~` 退出...
就ok了...


 我是指针,却丢失了目标地址!          我是循环,却缺少了结束条件!      我是函数,却没有人来调用!   
2007-05-07 11:08
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
for(int i=0,j=n-1;i<j;i++,j--)
{
if(*(p+i)!=*(p+j))
{
return 0;
}
}
return 1;

倚天照海花无数,流水高山心自知。
2007-05-07 11:30
heecn
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-6-30
收藏
得分:0 
以下是引用I喜欢c在2007-5-7 11:06:31的发言:
for(p=string;*p!='\0';p++);
p--;
可该为 p=string;p+=(strlen(string)-1);

其实都一样的啊,都是求出字符串最后一个字符的地址,整个程序都没反应。

2007-05-07 14:06
heecn
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-6-30
收藏
得分:0 
以下是引用I喜欢c在2007-5-7 11:08:33的发言:

你就判断第一个个最后一个是否一样
一样继续判断第二个和倒数第二个...
不一样就不是~` 退出...
就ok了...

#include<stdio.h>
#include<string.h>
int palindrome(char *string)
{
char *p,*q;
for(p=string;*p!='\0';p++);
p--;
q=string;
while(p!=q&&(q-p)!=1)
{
if(*p!=*q) break;
p--;q++;
}
if(p==q||(q-p)==1) return 1;
else return 0;

}
void main()
{
char *str="aabaa";
palindrome(str);
getch();
}
我这样也写过但是也是没结果啊

2007-05-07 14:07
潇湘夜雨
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-5-1
收藏
得分:0 
没有结果是因为你没有输出,你可以在main函数中这样写:
if(palindrome(str))
printf(“Yes”);
else
printf("No");

长风破浪会有时, 直挂云帆济沧海。 C++ing!
2007-05-07 14:59
heecn
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-6-30
收藏
得分:0 
以下是引用潇湘夜雨在2007-5-7 14:59:28的发言:
没有结果是因为你没有输出,你可以在main函数中这样写:
if(palindrome(str))
printf(“Yes”);
else
printf("No");

果真是这样的~~谢谢
#include<stdio.h>
#include<string.h>
int palindrome(char *string)
{
char *p,*q;
for(p=string;*p!='\0';p++);
p--;
q=string;
while(p!=q&&(q-p)!=1)
{
if(*p!=*q) break;
p--;q++;
}
if(p==q||(q-p)==1) return 1;
else return 0;

}
void main()
{
char *str="aabaa";
if(palindrome(str))
printf("Yes");
else printf("No");
getch();
}

2007-05-07 15:29
快速回复:[求助]判断字符串是否回文,不知道我哪里写错了
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017233 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved