琐记4:判断回文

编写一个能判断一字符串是否为回文的程序,回文即:"asdfghjhgfdsa"这样的字符串:
int fun(char *p)
{
	if (p == NULL)
		return -1;
	
	char *pstart = p;
	char *pend   = p;
	
	while (*pend)
	{
		pend++;
	}
	pend--;
	
	while (pstart < pend)
	{
		if (*pstart != *pend)
			return 0;
		
		pstart ++;
		pend --;
	}
	
	return 1;
}

首先判断是否出错,出错返回-1,然后定义2个指针分别指向字符串的头和尾,

设定一个循环来判断它前后2个字符是否相同,一旦有不同的则返回0,否则就是回文,返回1。

这个程序其实很简单,但为什么要拿出来讲呢,主要是因为我自己做这道题目的时候犯了一个很严重的错误。

当时,我的想法是,将先定义一个字符数组保存下这个字符串,再将它逆序,然后利用strcpy函数比较它是否发生了变化。

但执行下来却发现,始终是段错误。究其原因,是一个老生常谈的问题,用指针改变了字符串常量的值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值