---恢复内容开始---
| 这个教程属于哪个教程 | C语言程序设计II |
| 这次作业要求在哪里 | https://edu.cnblogs.com/campus/zswxy/computer-scienceclass3-2018/homework/3078 |
| 我在这个课程的目标是 | 动态内存分配与字符串处理函数 |
| 这个具体在哪个方面帮助我实现目标的 | 设计类似于输出学生成绩的应用 |
| 参考文献 | c语言程序设书籍和百度 |
6-1 函数实现字符串逆序
本题要求实现一个字符串逆序的简单函数。
函数接口定义:
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
设计思路:

运行结果截图:

在编写的中途误用了if语句,后与搭档讨论过后改用while语句
6-3 字符串的连接
本题要求实现一个函数,将两个字符串连接起来。
函数接口定义:
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] = {'