一、PTA实验作业

题目1:使用函数输出水仙花数

1. 本题PTA提交列表



2. 设计思路

(1)首先定义函数narcissistic(number)判断number是否为水仙花数:

(2)narc用于存放各个数的count次方的累加结果,total为各个位上的数的count次方,N为各个位上的数,M保留number的初值,count为number的位数,i,k为循环变量;

(3)把number的值赋给M,赋narc和count的初值为0;

(4)while(number!=0)时 ,执行下一步骤;

(5)number=number/10; count++;

(6)重复执行第四步骤直到number等于0;计算得到的count为number的位数;

(7)number=M,number的初值重新赋回;

(8)i=1;当i小于等于count的时候,执行下一步骤;

(9)N=number%10,totle=1;

(10)利用循环语句计算N的count次方;

(11)number=number/10,narc=narc+totle;

(12)i++,重复执行第八步骤直到i大于count;

(13)如果narc等于M,则输入的数为水仙花数,return 1;

(14)否则return 0;

(15)定义PrintN(m,n)在m到n的范围内找水仙花数 :

(16)利用循环语句和调用narcissistic函数来找范围内的水仙花数;

(17)若是则输出该数并换行。

3.本题调试过程碰到问题及PTA提交列表情况说明。

(1)一开始没有直接调用narcissistic函数来找水仙花数,再写了一遍类似于narcissistic函数的内容,导致代码非常长,特别容易出现编辑错误,而且很难找错,两个函数相近又有很多变量名,看起来杂乱无章,可读性很低。
(2)第一次没有审题好,没有考虑number的位数,所有的数都是乘三次方;第二次改成下图,因为不想再定义一个变量,所有直接用N来累乘,没有考虑到两个N都会发生改变,导致答案错误;就重新定义一个变量total为各个位上的数的count次方。

修改后:

题目2:使用函数验证哥德巴赫猜想

1. 本题PTA提交列表





2. 设计思路

(1)定义函数prime(p)判断用户传入参数p是否为素数:

(2)如果p为1,不是素数则返回0;如果p为2,是素数则返回1;

(3)i=2,当i小于P时执行下一步骤;

(4)判断p能否整除i;

(5)如果能整除则不是素数,结束循环;

(6)判断此时的i是否大于p/2,若是则为素数,return 1;

(7)i++,重复执行第三步骤直到i=p位置。

(8)定义 Goldbach(n)函数输出n的素数分解:

(9)输出“n = ”;

(10)number=2;当number小于n时,执行下一步骤;

(11)判断 prime(number)是否等于1且prime(n-number)是否等于1;

(12)同时成立时输出number+n-number,结束判断;

(13)number++,重复执行第十步骤,直到number等于n时为止。

3.本题调试过程碰到问题及PTA提交列表情况说明。

(1)一开始只判断了1不是素数,没有判断2时素数,所有当p等2时结果错误;

(2)prime(p)函数中用while语句判断素数时没有考虑好范围,结果没有办法正确判断,通过调试找出死循环,后改成for语句;
(3)Goldbach(n)函数中不知道如何进行素数分解,没有直接调用prime(p)函数时,以为要判断第一个素数后,用n-number输出第二个数就可以了,运行后发现n-number不一定是素数;后面又把n-number写错成number-n,第二个数输出时就变成了负数;直接调用prime(p)函数判断两个数同时是素数,然后输出即可;

(4)在判断number和n-number是否是素数同时成立时,输出一次即可;没有加上break会一直判断,运行时会输出所有结果。

题目3:求组合数

1. 本题PTA提交列表



2. 设计思路

(1)函数声明fact(n)计算n的阶乘;

(2)定义result来存放结果;

(3)输入m和n;

(4)result=fact(n)/(fact(m)fact(n-m)),函数调用求组合数;

(5)输出结果;

(6)定义函数fact(n);

(7)定义product用于存放结果,i为循环变量;

(8)i=1,当i小于等于n时,执行下一步骤;

(9) product=product
i;

(10)i++,重复执行第8步骤直到i大于n为止;

(11)返回product的值

3.本题调试过程碰到问题及PTA提交列表情况说明。

(1)函数声明时没有分号,导致编辑错误;因为前面写的都是函数定义,没有注意到这个细节;
(2)变量product没有定义成double的类型,虽然构思的时候有想到,但是写代码的时候又忘记了;

二、同学代码结对互评

1.同学互评照片。

2.我的代码、互评同学代码截图。

我的代码
int narcissistic( int number )
{
int narc,M,N,count,i,totle,k; //narc用于存放各个数的count,次方的累加结果,total为各个位上的数的count次方
M=number; //N为各个位上的数,M保留number的初值,count为number的位数
narc=0;
count=0;
while(number!=0){ //计算count的值
number=number/10;
count++;
}
number=M; //number的初值重新赋回
for(i=1;i<=count;i++){
N=number%10;
totle=1;
for(k=1;k<=count;k++) //计算total;
totle=totle*N;
number=number/10; //number去个位
narc=narc+totle; //计算narc
}
if(narc==M) //比较narc与M的值,若相等则为水仙花数
return 1;
else
return 0;
}
void PrintN( int m, int n )
{
int i;
for(i=m+1;i<=n-1;i++){ //在m到n的范围内找水仙花数
if(narcissistic(i)==1)
printf("%d\n",i);
}
}
林岑的代码
int narcissistic( int number )
{
int i,j,k,sum,l,n;
k=number;i=0;l=number;n=number;
while(k!=0){
k=k/10;
i++;
}
while(l!=0){
l=n%10;
sum=1;
for(j=1;j<=i;j++){
sum=sum*l;
}
k=k+sum;
l=(n-l) /10;
n=n/10;
}
if(k==number)
return 1;
else
return 0;
}
void PrintN( int m, int n )
{
int i,j,k,sum,a,l,h;
for(a=m+1;a<n;a++){
k=a;i=0;l=a;h=a;
while(k!=0){
k=k/10;
i++;
}
while(l!=0){
l=h%10;
sum=1;
for(j=1;j<=i;j++){
sum=sum*l;
}
k=k+sum;
l=(h-l) /10;
h=h/10;
}
if(k==a)
printf("%d\n",a);
}
}

3.我和同学代码不同在哪里?有哪些各自优势?你更喜欢哪种代码风格?如果同学代码有错的也请帮忙指出来哪里出问题。

  • 不同:(1)我的代码在第二次函数中直接调用了第一个函数,少了重新判断的内容,所以代码会比较短一些;

    同学的代码中是重新判断了水仙花数,不过她的两个函数中变量名一样,比较整洁;我第一次没有直接调用第一个函数时,第二个函数的变量名又设的不一样,很容易眼花缭乱。

    (2)同学判断水仙花数的条件和我不一样,她是以个位数为判断条件,这样的话如果数的中间有0的话就没办法继续判断,所以还要多加一条语句来改正;如果用number的话,直接取个位再去个位就不用考虑中间夹0的情况了。
  • 我会更喜欢自己代码些,可能比较适应自己思考方式吧,觉得比较容易接受。

三、截图本周题目集的PTA最后排名。(2分)

PTA排名

四、本周学习总结(2分)

1.你学会了什么?

  • C语言哪些数据类型?

    (1)整型:整型,短整型,长整型,无符号整型,无符号短整型,无符号长整型;

    (2)字符型:字符型;

    (3)浮点型:单精度浮点型,双精度浮点型;
  • 字符型数据需要注意地方?

    (1)可以用整数来表示字符;

    (2)互换整型变量和字符型变量的定义和值时,整型数据的取值范围是有效的ASCII码;

    (3)转义字符是由反斜杠加上一个字符或数字组成,形式上由多个字符组成,实际上只代表一个字符。
  • 自增自减运算符?

    (1)++n=n+1,n++=n;

    (2)自增运算符和自减运算符的运算对象只能是变量;

    (3)结合方向:右结合(从右向左)。
  • 运算符优先级?

    (1)单目运算优于双目运算;

    (2)先乘除,后加减;

    (3)先算术运算,后移位运算,最后位运算;

    (4)逻辑运算最后计算。
  • C语言哪些表达式?课堂派哪里做错,做错的请在这里分析原因?

    (1)算数表达式,赋值表达式,关系表达式,逻辑表达式,条件表达式和逗号表达式;

    (2)######课堂派



    x本身为浮点型,所以经过整除运算后得到的2要变成浮点型;



    逻辑或语句只要有一个值为真就会结束不再继续执行,所以这道题执行完++x后就结束了,没有执行y++,所以y的值没有改变。

2.本周的内容,你还不会什么?

  • 运算符优先级并不是很明确,容易混淆;
  • 一下子学了好多表达式和运算符,还不是很能接受;
  • 函数的PTA完成的不太好,调试了很久才找出错误,如果是考试的话根本来不及。

3.循环结构考试总结(全部同学都要写)

(1)哪题做错了,怎么改?

  • 第二题:字符问题,一直掌握不好,老师之前详细的讲解过空心菱形的题目,把那道题再看看研究好字符的应用;
  • 第四题:题目要求在一行中按递减顺序输出10个满足条件的素数,利用count来控制输出个数,但是没用实现;
  • 第五题:还没有写出正确答案。

(2)考试结果满意么,怎么改进?

  • 很差,考试的时候都没什么好点的思路,写的代码又很乱,太紧张了犯了些小错误,花了很多时间去修改;
  • 本次考试的题目有些是老师讲过或者做过的,没有很大难度,但是自己却做不好,平时做过的题目还是没有下功夫研究和总结;
  • 看了一些同学的代码,明显解题思路要好很多,不仅清晰而且简单,希望通过看看别人写的代码能够提高这方面的能力;然后平时做过的作业要经常看看,注意错误点。

最新文章

  1. 网络编程之socket新解
  2. vijos 1006 spfa **
  3. Effective C# 学习笔记(原则一:始终能的使用属性(property),而不是可直接访问的Data Member)
  4. Netty4.0学习笔记系列之三:构建简单的http服务(转)
  5. Visual c++例子,可不使用常规的对话框资源模板的情况下,动态创建对话框的方法
  6. ios 点击放大图片,保存至手机相册
  7. OpenCV成长之路:图像滤波
  8. codeforces 755C. PolandBall and Forest
  9. JS中的一元操作符
  10. redis集群搭建及设置账户(转)
  11. 《转载》JVM垃圾回收机制
  12. 各个版本的jee(servlet,jsp)对应的web.xml的模板
  13. LINUX系统一一CentOS6.5之安装JDK
  14. codeM 2018 资格赛
  15. Angular的表单组件
  16. 接口测试工具--Poster与Postman的简单实用
  17. maven构建jar包
  18. cocos2dx ScrollView的用法
  19. Core Animation 与 GPU
  20. LINUX 11G RAC ASM磁盘组在线增加磁盘扩容

热门文章

  1. google浏览器插件推荐
  2. Monkeyscript---获取包名主界面名和位置坐标
  3. Supermarket POJ - 1456
  4. 【JDK1.8】JUC.Lock综述
  5. 浅析Java 8新特性Lambda Expression
  6. setTimeout模拟interval
  7. linux 下oracle 11g静默安装(完整版)
  8. PowerShell 发布farm solution
  9. 1111 WordReplace
  10. 面向对象设计模式_生成器模式详解(Builder Pattern)