问题 | 答案 |
---|---|
这个作业属于那个课程 | C语言程序设计II |
这个作业要求在哪里 | C语言I博客作业09 |
我在这个课程的目标是 | 熟练掌握C语言 |
这个作业在哪个具体方面帮助我实现目标 | 学会了如何去使用for嵌套来做编程题,熟悉了break、continue的使用方法,了解了字符型的输入 |
参考文献 | Markdown基本语法 |
一.PTA实验作业
1. 换硬币
题目内容描述:将一笔零钱换成5分、2分和1分的硬币,要求每种硬币至少有一枚,有几种不同的换法?
输入格式:
输入在一行中给出待换的零钱数额x∈(8,100)。
输出格式:
要求按5分、2分和1分硬币的数量依次从大到小的顺序,输出各种换法。每行输出一种换法,格式为:“fen5:5分硬币数量, fen2:2分硬币数量, fen1:1分硬币数量, total:硬币总数量”。最后一行输出“count = 换法个数”。
输入样例:
13
输出样例:
fen5:2, fen2:1, fen1:1, total:4
fen5:1, fen2:3, fen1:2, total:6
fen5:1, fen2:2, fen1:4, total:7
fen5:1, fen2:1, fen1:6, total:8
count = 4
(1)数据处理
数据表达:
用了整形变量x,fen5,fen2,fen1,count=0
x是用户传入的要求计算零钱数额
fen5,fen2,fen1,count=0分别用来保存用户要求输出的5分硬币数量,2分硬币数量,1分硬币数量和换法个数
数据处理:伪代码
定义整型变量x,fen5,fen2,fen1,count=0; x为输入的钱数,fen5为5分钱的个数,fen2为2分钱的个数,fen1为1分钱的个数,count为多少种换法。
输入用户要求的钱数x;
for(fen5=x/5; fen5>=1; fen5--)
for(fen2=x/2; fen2>=1; fen2--)
计算出一分硬币的个数
if(fen1>=1)
输出5分,2分,1分硬币的个数和硬币总数
count换法累加
end for
end for
输出换法个数
(2)实验代码截图
(3)造测试数据
输入数据 | 输出数据 | 说明 |
---|---|---|
9 | fen5:1, fen2:1, fen1:2, tatal:4 count : 1 | 最小x |
99 | 最大x | |
88 | 随机试验 | |
20 | 随机试验 |
(4)PTA提交列表及说明
提交列表说明
1.答案错误:误将total打为tatal,开始没有看出来,以为是像第一题一样要左对齐在d前加了一个-2
2.答案错误:误将total打为tatal,不应该将%d改为%-2d,将total改为tatal,将%d改回来后答案正确
刚开始做的时候定义了一个x1用来保存输入钱数减去8后的数,后来发现这样定义太麻烦还要定义其他的数来储存减去8后即每个方法中的每种硬币的个数减一的数,而且完全没有必要这样子做,后面做博客园的时候发现变量x1忘记删除了,后来将x1删除又提交了一次截的图。
2. 找完数
题目内容描述:所谓完数就是该数恰好等于除自身外的因子之和。例如:6=1+2+3,其中1、2、3为6的因子。本题要求编写程序,找出任意两正整数m和n之间的所有完数。
输入格式:
输入在一行中给出2个正整数m和n(1 输出格式: 逐行输出给定范围内每个完数的因子累加形式的分解式,每个完数占一行,格式为“完数 = 因子1 + 因子2 + ... + 因子k”,其中完数和因子均按递增顺序给出。若区间内没有完数,则输出“None”。输入样例:
2 30
输出样例:
6 = 1 + 2 + 3
28 = 1 + 2 + 4 + 7 + 14
(1)数据处理
数据表达:
用了整形变量n,m,i,j,sum,flag=0
n,m是用户传入的要求找完数的范围
i用来保存在n、m范围内的每一位数
j用来保存从2开始每一个小于i的数,用来找因子
sum用来保存一个数的所有因子和,用来判断数的因子和是否等于这个数
flag立一个flag用来判断该数是否属于完数
数据处理:伪代码
定义变量n,m,i,j,sum,flag=0,n和m为用户输入的数,i和j用于循环,sun用来保存数的因子和,flag用来判断该数是否属于完数
输入m和n
for(i=m;i<=n;i++)
对sum初始化为1
for(j=2;j
(2)实验代码截图
(3)造测试数据
输入数据
输出数据
说明
6 28
6 = 1 + 2 + 3 28 = 1 + 2 + 4 + 7 + 14
取完数为边界
2 9999
最大范围
10 20
None
空集
6 6
6 = 1 + 2 + 3
6==6
(4)PTA提交列表及说明
提交列表说明
一次性正确,第一次提交的代码多加了一个if(i==1) contiune;用来判断i是否等于1,如果i=1则结束本次循环,后来做博客园的时候发现题目中说了1
二.代码互评
同学(柏朝晖)代码
同学(杨宇)代码
自己代码
比较
(1)第一份代码用了三层循环嵌套,第一层用来处理5分硬币个数,第二层用来处理2分硬币个数,第三层处理1分的;而我的代码是用两个for循环嵌套处理fen5和fen2,然后再根据剩余的钱计算出fen1的个数,再判断fen1>=1是否成立来确定是否能构成题目要求的一种分硬币的方法。相对来说他的代码因为第三层for使编译时间比我的长,相比较之下,我的代码更好一些。
(2)第一份定义变量用的是数字5、2、1的英文字母而我自己用了题目输出示例的字母来定义变量,相对来说我的更容易见名知意。第二份的定义的变量也有点奇怪
(3)第二份跟我最开始的思路一样,先将输入的钱数减去8,即减去每种硬币一个加起来的钱数。然后就可以只用两层for循环分别了处理5分的和2分的,1分的就可以直接用`x-5*i-2*m+1`来解决,而我的代码还用了一个if(fen1>=1)来判断是否能构成题目要求的一种分硬币的方法。相比较之下,她的代码思路比较好。
三.学习总结
1.学习进度条
周/日期
这周所花的时间
代码行
学到的知识点简介
目前比较迷惑的问题
第四周
7小时
100行
在屏幕上显示Hello World!
暂无
第五周
8小时
100行
求华氏温度对应的摄氏温度
暂无
第六周
30小时
200行
如何用 MinGW-w64 来编译C程序
暂无
第七周
24小时
300行
运用if语句完成各种数学程序
对于&&的用法不了解
第八周
24小时
300行
学会了for循环语句
暂无
第九周
24小时
300行
学会了如何去自定义一个函数
暂无
第十周
30小时
400行
学会了if-else语句的嵌入
对“(Y%100)这个表达式意味着当Y不能整除4时(Y%100的余数不等于0时)表达式为真”这句话不是很懂
第十一周
24小时
450行
学会了如何去使用switch语句来做编程题
暂无
第十二周
24小时
450行
学会了如何去使用while循环来做编程题
对字符型的输入不太了解
第十三周
26小时
372行
学会了如何去使用for嵌套来做编程题,学会了continue的使用方法
对字符型的输入和输出不太了解,对数组完全不了解
2. 累积代码行和博客字数
时间
博客字数
代码行数
第四周
510
100
第五周
510
200
第六周
1149
400
第七周
2027
700
第八周
3791
1000
第九周
5294
1300
第十周
6900
1700
第十一周
8614
2150
第十二周
10495
2600
第十三周
13019
2972
3 .学习内容总结和感悟
(1)学习内容总结
(2) 学习体会
现在我的学习进度完全是跟着老师走的,而且老师上课讲的东西有时候还不能熟练运用,而别人早已经走到前面去了。对别人来说一个小时就能将PTA做完而我有时候做一个题目想3、4个小时还没有思路最后只能求助百度,我觉得我应该反思一下了。
以后尽量多刷点题目扩展一下逻辑思维能力,有剩余时间的话提前预习一下数组,感觉很多题目都要用到这个东西。
感觉调试有点难搞,每次机课作业都很赶,需要多练习一下,学好了调试以后就好找代码出现的错误了。