1.本章学习总结(2分)
1.1 思维导图
1.2 本章学习体会及代码量学习体会
1.2.1 学习体会
本周学习了指针,都说指针是C语言的灵魂,也是C语言区别于其他语言所独特的地方,学好指针的相关内容十分必要,但同时难度也更大,需要付出更多的时间去理解和熟练掌握。学习到指针部分之后明显感觉有点吃力,虽然也和前面的知识结合紧密,但是需要对指针的概念搞得很清楚,不然就会把地址和该地址所存的内容搞混。然后指针上完之后老师又教了结构体和文件相关的内容,真的要认真学习多花时间才能完全理解掌握。目前的自己觉得还是一直半解,蛮吃力的。
在数据传递时,如果数据块较大,这时就可以使用指针传递地址而不是实际数据,即提高传输速度,又节省大量内存。
指针为动态数据结构(如二叉树、链表)提供支持
1.2.2 代码累计
2.PTA总分(2分)
2.1截图PTA中函数题目集的排名得分
3.PTA实验作业(1分)
3.1 PTA题目1
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
33.1.1 算法分析
int main()
{
定义字符数组 str[500010];
输入gets(str);
定义长度变量len;
len=strlen(str);
定义i,j,count=0;
定义flag=0;
for i=len-1 to i>=0 do
if str[i]!=' ' then
count++;//计算字符数
end if
else if str[i]==' '&&count!=0 then
for j=i+1 to str[j]!=' '&&str[j]!=0 do
输出字符
end for
for j=i to j>=0 do
if str[j]!=' ' then
break;
end if
if j==0 then
flag=1;
end if//遍历后面是否还有字符
if flag==0 then
输出空格
count=0;
end if
end for
end for
for i=0 to i
3.1.2 代码截图
3.1.4 PTA提交列表及说明
- Q1:开始有一个测试点最小值,前面有空格过不去
- A1:后来发现若第一个单词后面有空格,输出也会带空格,出现格式错误,所以定义一个flag,并判断后面是否还有字符,若有字符则输出一个空格,没有字符即到了最后一个单词的输出,就不输出空格
- Q2:
- A2:其实开始时的代码写的比较复杂,然后最后一个测试点一直过不去,也没有找出解决办法,可能是输出出了问题?
4.大作业(5分)
题目:实现小学四则运算。
在函数那章,我们已经实现小学四则运算这份作业,现在要求大家把之前设计函数升级改造,原来的函数大家都是用全局变量实现不同函数参数传递,这次作业要求改地址传递,减少全局变量的使用。
4.1.改造函数介绍
1.函数1
伪代码
int main()
{
定义字符数组 exp[100]={0};
定义整型变量 level,amount,right;
定义浮点型变量 accuracy;
定义整型变量 youranswer=0,myanswer=0;
输出menu---------------------------简单四则运算训练系统------------------------------\n 欢迎进入训练\n
等级1:1位数的一步加减乘除计算训练\n等级2:2位数的2步加减运算\n等级3:3位数的2步加减运算\n请选择等级:
输入level
while level!=1&&level!=2&&level!=3
fflush(stdin);//输入非法字符时清除缓冲区数据重新输入
输出 输入错误,请重新输入\n
输入level
end while
输入 请输入题目数量:
while !scanf("%d",&amount) //判断是否输入非法字符
fflush(stdin);
输出 输入错误,请重新输入\n
end while
定义整型变量 n;
定义 flag=0;
for n=0 to n
2.函数2
伪代码
void CreateExp(char *exp,int level)
{
srand(time(NULL));
定义整型变量 x,y,z;
定义整型变量 ch1,ch2;
if level==1 then
ch1=rand()%4;
else
ch1=rand()%2;
ch2=rand()%2;
end if//生成运算符
switch(level)
{
case 1:
x=rand()%10;y=rand()%10;
itoa(x,exp,10); 将变量x的数据类型转为字符型
switch(ch1)
case 0:strcat(exp,"+");break;
case 1:strcat(exp,"-");break;
case 2:strcat(exp,"*");break;
case 3:strcat(exp,"/");break;
end switch
strcat(exp,itoa(y,exp+3,10));
break;//一级
case 2:
x=rand()%100;y=rand()%100;z=rand()%100;
itoa(x,exp,10);
switch(ch1)
case 0:strcat(exp,"+");break;
case 1:strcat(exp,"-");break;
end switch
strcat(exp,itoa(y,exp+4,10));
switch(ch2)
case 0:strcat(exp,"+");break;
case 1:strcat(exp,"-");break;
end switch
strcat(exp,itoa(z,exp+7,10));
break;//二级
case 3:
x=rand()%1000;y=rand()%1000;z=rand()%1000;
itoa(x,exp,10);
switch(ch1)
case 0:strcat(exp,"+");break;
case 1:strcat(exp,"-");break;
end switch
strcat(exp,itoa(y,exp+5,10));
switch(ch2)
case 0:strcat(exp,"+");break;
case 1:strcat(exp,"-");break;
end switch
strcat(exp,itoa(z,exp+9,10));
break; //三级
end switch
strcat(exp,"=");
puts(exp);
//生成exp
构建表达式函数经老师指点后修改
- 这样明显简便很多,之前的方法一直调用函数strcat和itoa函数,代码质量不高,效率很低
3.函数3
伪代码
int Answer(char *exp,int level)
{
定义整型变量 answer;
answer=*exp-'0';//将字符型转为整型
定义i;
for i=0 to *(exp+i)!=0
if *(exp+i)=='+'||*(exp+i)=='-'||*(exp+i)=='*'||*(exp+i)=='/' then
switch(*(exp+i))
case '+':answer=add(answer,*(exp+i+1)-'0');break;
case '-':answer=sub(answer,*(exp+i+1-'0'));break;
case '*':answer=mul(answer,*(exp+i+1)-'0');break;
case '/':answer=divide(answer,*(exp+i+1)-'0');break;
end switch
end if
end for
return answer;
int Judge(int youranswer,int myanswer)
{
定义整型变量 right=0;
if youranswer==myanswer then
printf("答案正确!\n");
right++;
else
printf("答案错误,正确答案为%d\n",myanswer);
end if
return right;
}
4.3 与原有函数代码比较
函数1
原函数
原来的main函数实在是太太太长了,这里就不放上来了,总体就是不简练,没有分割不同功能的函数,而一味的都写在main函数中
函数2
- 不同: 原来的main函数中内容太多了,看起来有点乱,需要花费更多时间去分割每部分语句的功能,改造后main函数中只保留了主菜单部分,并且写了构建表达式,计算答案,判断正误三个函数。
- 优点:main函数中没有太多的语句,只有主要功能的语句,这样程序看起来思路清晰很多。使用多个函数将功能分开,大大加强了程序的拓展性,对于以后对程序的进一步修改和增加功能非常有帮助。
- 缺点:功能还有待完善,对于非法字符的处理可能也还有其他更好的方法。
4.4 改进大作业总结:
这次大作业主要就是加强了自己对于函数分装还有指针的运用,刚开始的方法虽然定义了指针但是感觉并没有完全用上,后来老师指导和参考同学的以后修改了,算是真正有用上指针了,这次的主要感受就是要加强自己在指针运用方法的练习,以及对于你想写怎么的程序有一个大致的规划,这对于后续的函数分装和程序的拓展性怎样非常重要,然后就是,继续加油吧~