本题要求实现一个字符串逆序的简单函数。
函数接口定义:
void f( char *p );
函数f
对p
指向的字符串进行逆序操作。要求函数f
中不能定义任何数组,不能调用任何字符串处理函数。
裁判测试程序样例:
#include <stdio.h>
#define MAXS 20
void f( char *p );
void ReadString( char *s ); /* 由裁判实现,略去不表 */
int main()
{
char s[MAXS];
ReadString(s);
f(s);
printf("%s\n", s);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
Hello World!
结尾无空行
输出样例:
!dlroW olleH
结尾无空行
示例答案:
void f( char *p ){
int i,len;
char bibi;
for(i=0;;i++){
if(p[i]=='\0'){
len=i;//计算字符串的长度
break;
}
}
if(len%2==0)//if语句判断是奇数个还是偶数个
{
for(i=0;i<len/2;i++){
bibi=p[i];
p[i]=p[len-1-i];
p[len-1-i]=bibi;
}
}
else {
for(i=0;i<(len-1)/2;i++){
bibi=p[i];
p[i]=p[len-1-i];
p[len-1-i]=bibi;
}//分成奇数和偶数两种情况实现字符串交换。这一段可以再优化。
}
} //这个程序能写得更加简单,但是笔者水平有限,无法再精简了,请各位指正