6-1 函数实现字符串逆序 (15 分)
本题要求实现一个字符串逆序的简单函数。
函数接口定义:
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 ", s); return 0; } /* 你的代码将被嵌在这里 */
输入样例:
Hello World!
输出样例:
!dlroW olleH
实验代码:
void f( char *p )
{
int i=0,q=0,h,tmp;
while(p[i]!=' ')
i++;
h=i-1;
while(q<=h)
{
tmp=p[q];
p[q]=p[h];
p[h]=tmp;
q++;
h--;
}
return ;
}
设计思路:
运行结果截图:
6-3 字符串的连接 (15 分)
本题要求实现一个函数,将两个字符串连接起来。
函数接口定义:
char *str_cat( char *s, char *t );
函数str_cat
应将字符串t
复制到字符串s
的末端,并且返回字符串s
的首地址。
裁判测试程序样例
#include <stdio.h> #include <string.h> #define MAXS 10 char *str_cat( char *s, char *t ); int main() { char *p; char str1[MAXS+MAXS] = {'