2019春第八周作业
这个作业属于那个课程 | C语言程序设计II |
这个作业要求在哪里 | https://edu.cnblogs.com/campus/zswxy/software-engineering-class2-2018/homework/3074 |
我在这个课程的目标是 | 熟练运用指针 |
这个作业在那个具体方面帮助我实现目标 | 指针字符数组的处理 |
参考文献 | 算法入门经典 |
第一题
-1 函数实现字符串逆序 (15 分)
本题要求实现一个字符串逆序的简单函数。
函数接口定义:
void f( char *p );
函数f
对p
指向的字符串进行逆序操作。要求函数f
中不能定义任何数组,不能调用任何字符串处理函数。
裁判测试程序样例:
1 #include <stdio.h> 2 #define MAXS 20 3 4 void f( char *p ); 5 void ReadString( char *s ); /* 由裁判实现,略去不表 */ 6 7 int main() 8 { 9 char s[MAXS]; 10 11 ReadString(s); 12 f(s); 13 printf("%s ", s); 14 15 return 0; 16 } 17 18 /* 你的代码将被嵌在这里 */
输入样例:
Hello World!
输出样例:
!dlroW olleH
实验代码
1 void f(char * p) 2 { 3 int len = strlen(p); 4 for(int i = 0 ; i < len/2 ; i++){ 5 char a = p[i]; 6 p[i]=p[len-i-1]; 7 p[len-i-1]=a; 8 } 9 10 return; 11 }
设计思路
实验过程中遇到的问题及解决方法
一开始把P[len-i-1]粗心换成了P[len-i]导致最后一个元素出差错
运行结果截图
第二题
6-3 字符串的连接 (15 分)
本题要求实现一个函数,将两个字符串连接起来。
函数接口定义:
char *str_cat( char *s, char *t );
函数str_cat
应将字符串t
复制到字符串s
的末端,并且返回字符串s
的首地址。
裁判测试程序样例:
1 #include <stdio.h> 2 #include <string.h> 3 4 #define MAXS 10 5 6 char *str_cat( char *s, char *t ); 7 8 int main() 9 { 10 char *p; 11 char str1[MAXS+MAXS] = {'