一、PTA实验作业
题目1:使用函数实现字符串部分复制
1. 本题PTA提交列表

2. 设计思路

3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明
- 赋值时减去t+m还要再减去1。
 
题目2:求子串在母串中最后一次出现的地址
1. 本题PTA提交列表

2. 设计思路
    定义字符指针变量s1,s2,a;
    赋值a=NULL;
    while(*s)
        s1=s; s2=t;
        while(*s2)
            判断*s2是否等于*s1,如果是s1++;s2++; 否则结束循环;
            如果*s为空,则a=s;
            s++;
    返回a;
3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明
- 要定义一个返回函数值NULL的指针。
 
题目3:字符串串动变化
1. 本题PTA提交列表

2. 设计思路
    定义字符变量max,指针a;定义变量i=0;
    max=p[i];
    while(p[i])
        如果max小于p[i];
            a=p+i;
            max=p[i];
        i++;
    while(*a)
        将字符后移,并且第一个为max;
3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明
- 无。
 
二、截图本周题目集的PTA最后排名

三、阅读代码
IP地址转换
#include<stdio.h> int main() { char s[33],c; int sum=0,put[4],cnt=0; for(int i=1;i<=32;i++){ c=getchar(); sum=sum*2+c-‘0‘; if(i%8==0){ put[cnt++]=sum; sum=0; } } printf("%d.%d.%d.%d",put[0],put[1],put[2],put[3]); return 0; }- 该代码利用ip地址规定的4个二进制转十进制的数定义了数组put来存放,用一句sum=sum*2+c-‘0‘直接实现字符和整形的转换和二进制和十进制的转换,在8个字符后重新赋值sum。代码很巧妙,所以很简短。
 - 这是吴军霖同学PTA中 删除字符串中的子串的代码。

 他总共才用了19行代码,而网上的都是几十行的复杂代码,可见他的代码十分简洁,这种删除子串的方式构思巧妙,通过重构母串数组s来达成删除子串的目的。效率较高,占用空间也较小。
四、本周学习总结
1.自己总结本周学习内容
- 学会了指针的基本使用,但对它的概念还不是很熟。
 - 学会了使用函数将数组和指针进行传递。
 学会了字符串的一些函数,极大提高对字符串的操作。
2.罗列本周一些错题

