C语言博客作业--函数

本文介绍了C语言中的函数应用,包括水仙花数判断、组合数计算及哥德巴赫猜想验证等PTA实验作业,同时对比了不同实现方式的优劣。

一、PTA实验作业

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

1. 本题PTA提交列表

1233778-20171118161115374-2023576597.png

2.设计思路

-水仙花数判断(int narcissistic( int number )):
  • 1.计算接收的数字number的位数,即幂数 for(i=number;i>0;i/=10) n++;
  • 2.计算各位数的n次幂之和 (i=number;i>0;i/=10) sum+=pow(i%10,N);
  • 3.当各位数n次幂之和sum==number,返回1,否则返回0;
-打印m到n之间的水仙花数:
  • 调用narcissistic()函数判断m到n之间的各数是否为水仙花数,输出其间所有水仙花数for(v=m+1;v<=n-1;v++) if(narcissistic(v)) printf("%d\n",v);

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

  • 无问题.

题目2:求组合数

1. 本题PTA提交列表

1233778-20171118162435749-170589852.png

2.设计思路

-定义fact()函数计算阶乘:
  • 定义初始化为1的变量flag
  • 计算并返回接收数字的阶乘 for(int i=1;i<=x;i++) fact*=i; return fact;
-主函数:
  • 定义变量m,n.输入m和n
  • 输出组合数result = fact(n)/( fact(m)*fact(n-m) ).

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

  • 无问题

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

1. 本题PTA提交列表

1233778-20171118163651984-118823046.png

2.设计思路

-定义prime()函数判断素数:
  • for(int i=2;i<=sqrt(num);i++) if(p%i==0) break;
    if(i>sqrt(num)&&num!=1) return 1;
    return 0;

    -输出分解式
  • 1.定义其中一个因子为p,则另一个因子为n-p
  • 2.循环判断p及num-p是否都为素数.
  • 3.因要求输出所有解中p最小的解,初设p为3,每完成一次循环p+=2
  • 4.当满足条件时,输出n=p+(n-p). 并退出循环
    if(prime(p))
    if(prime(n-p))
    {
    printf("%d=%d+%d",n,p,n-p);
    break;
    }

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

1233778-20171118232300312-410163216.png
一开始判断条件写错 p != 1 写成 i != 1导致输出全错. 改正后解决问题.

二、同学代码结对互评

1.同学互评照片。

1233778-20171118232748234-421293835.png

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

我的代码
int fib( int n )
{
    int flag,flag1=1,flag2=1;
    if(n==1||n==2) return 1;
    for(int i=3;i<=n;i++)
    {
        flag=flag1+flag2;
        flag1=flag2;
        flag2=flag;
    }
    return flag;
}
void PrintFN( int m, int n )
{
    for(int u=1;fib(u)<=n;u++){
        if(fib(u)>=m){
            printf("%d",fib(u));
            if(fib(u+1)>n) return ;
            printf(" ");
        }
    }
    printf("No Fibonacci number");
}
陈文杰的代码
int fib( int n )
{
    int count=0,total=0,middle=0,i;
    for(i=1;i<n;i++)
    {
        middle=count;
        total=total+middle;
        count=total-middle;
    }
    return total;
}
void PrintFN( int m, int n )
{
    int j,i,judge=0;
    if(m==1||m==0)
    printf("1 ");
    for(i=m;i<=n;i++)
    {         
        for(j=1;j<=100;j++)
        {
            if(fib(j)==i)
            {
                printf("%d",i);
                judge=i;
                i=10001;
            }
        }
    }
    if(judge!=0)
    {
        for(i=judge+1;i<=n;i++)
        for(j=1;j<=100;j++) if(fib(j)==i) printf(" %d",i);
    }
    if(judge==0) printf("No Fibonacci number");
}

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

  • 陈文杰用judge变量判断是否存在Fibonacci数.我的代码中,一旦满足m<=fib(u)<=n,即存在Fibonacci数时,函数便只会在循环内结束调用,否则将在循环结束时输出No Fibonacci number并结束函数调用.
  • 我更喜欢我的代码.

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

    1233778-20171118221323734-845251251.png

    四、本周学习总结

    1.你学会了什么?

    1.1 C语言哪数据类型?

  • 空类型(void); 整型(int),短整型(short),长整型(long); 单精度浮点型(float),双精度浮点型(double); 字符型变量(char).

1.2 字符型数据需要注意地方?

  • 字符型变量的输入只能接收一个字符.
  • 可以输出为整型或浮点型.
  • 可以用转义字符的方式输入.

1.3 自增自减运算符?

  • 自增(自减)运算符为单目运算符.即只需要一个变量.
  • 运算符:++(--)能使变量的值增加(减少)1
  • 如果运算符前置,则先运算再对表达式赋值;如果后置,则先对表达式赋值再进行运算.

1.4 运算符优先级?

1233778-20171118230734015-267532512.png

1.5 C语言哪些表达式?课堂派哪里做错,做错的请在这里分析原因?

  • 算术表达式(+ - * /)
  • 关系表达式(> >= < <= == !=)
  • 赋值表达式(-= += *= /= %= =)
  • 条件表达式:exp?:exp1,exp2; 当exp为真时,表达式的值为exp1的值,否则为表达式2的值.
  • 逗号表达式:表达式1,表达式2...表达式n 其表达式的值为表达式n的值.
  • 逻辑表达式:!,&&,||

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

  • 基本理解.

3.循环结构考试总结

  • 做第五题的时候有点急,改来改去发现在第一次提交的代码中加入一些判断就可以通过.
  • 本次考试结果能接受.
posted on 2017-11-19 00:01 嗡嗡_嗡 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/wu98/p/7857217.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值