法133计算机科学课第15周实践题目及参考解答

简介: 课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597编程练习1:输出1000以内的所有素数。参考解答:#include<stdio.h>#include<math.h>int main(){ int m,i,k,prime; for(m=2;m<=200;m++

课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597

编程练习1:输出1000以内的所有素数。

参考解答:

#include<stdio.h>
#include<math.h>
int main()
{
    int m,i,k,prime;
    for(m=2;m<=200;m++)
{
    prime=1;
    k=sqrt(m);
    for(i=2; i<=k; i++) //最多循环至……
        if(m%i==0)
        {
            prime=0;
            break;
        }
    if(prime==1)
        printf("%d ",m);
}
    return 0;
}

编程练习2:求满足条件n=a!+b!+c!的所有三位数n并输出,其中a,b,c分别为n的百、十、个位数。

参考解答:

#include<stdio.h>
int main()
{
    int n,a,b,c,sum;
    int i,f;
    n=100;
    while(n<1000)
    {
        sum=0;
        c=n%10;  //个位数,
        b=(n/10)%10;  //十位数
        a=n/100;  //百位数
        for(f=1,i=1; i<=a; ++i)  f=f*i; //求 a!
        sum += f;
        for(f=1,i=1; i<=b; ++i)  f=f*i; //求 b!
        sum += f;
        for(f=1,i=1; i<=c; ++i)  f=f*i; //求 c!
        sum += f; //此时sum的值为a!+b!+c!
        if(sum==n)  //若条件成立,则 n 就是要找的数。
            printf("%d ",n);
        ++n;  //考察下一个n
    }
    return 0;
}

解2:

#include<stdio.h>
int main()
{
    int n,a,b,c,sum;
    int i,f;
    for(n=100;n<1000;n++)
    {
        sum=0;
        c=n%10;  //个位数,
        b=(n/10)%10;  //十位数
        a=n/100;  //百位数
        for(f=1,i=1; i<=a; ++i)  f=f*i; //求 a!
        sum += f;
        for(f=1,i=1; i<=b; ++i)  f=f*i; //求 b!
        sum += f;
        for(f=1,i=1; i<=c; ++i)  f=f*i; //求 c!
        sum += f; //此时sum的值为a!+b!+c!
        if(sum==n)  //若条件成立,则 n 就是要找的数。
            printf("%d ",n);
    }
    return 0;
}

编程练习3:输入一个正整数,判断其是否为一个回文数(例1221、12321都是回文数)。提示:输入一个正整数n(例1234)后,构造出其反序数m(对应4321),若这两个数相等,则n是回文数(1234就不是回文数)。算法流程图如右图所示。

参考解答:

#include<stdio.h>
int main()
{
 
    int m,n,k;
    scanf("%d",&n);
    k=n;
    m=0;
    while(k>0)
    {
        m=m*10+k%10;
        k=k/10;
    }
    if(m==n)
        printf("%d是回文数\n",n);
    else
        printf("%d不是回文数\n",n);
    return 0;
}

编程练习4:输出1000以内的所有回文数。

参考解答:

#include<stdio.h>
int main()
{
 
    int m,n,k;
    for(n=0; n<1000; n++)
    {
        k=n;
        m=0;
        while(k>0)
        {
            m=m*10+k%10;
            k=k/10;
        }
        if(m==n)
            printf("%d ",n);
    }
    return 0;
}

编程练习5:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3,1、2、3是6的因子,所以6是完数。编程序,输入n,判断n是否是完数。

参考解答:

#include<stdio.h>
int main( )
{
    int i,n,s;
    scanf("%d",&n);
    s=1; //s表示因子和。1是任何数的因子,所以s=1,也使下一句可以从2开始尝试
    for(i=2; i<n; i++) //从2开始到n-1,逐个去试
    {
        if(n%i==0)
            s+=i;  //如果i是n的因子,则累加
    }
    if(n==s)
        printf("%d是完数\n",n);
    else
        printf("%d不是完数\n",n);
    return 0;
}

编程练习6:找出1000内的所有完数。

参考解答:

#include<stdio.h>
int main( )
{
    int i,n,s;
    for(n=2; n<1000; n++)
    {
        s=1; //s表示因子和。1是任何数的因子,所以s=1,也使下一句可以从2开始尝试
        for(i=2; i<n; i++) //从2开始到n-1,逐个去试
        {
            if(n%i==0)
                s+=i;  //如果i是n的因子,则累加
        }
        if(n==s)
            printf("%d ",n);
    }
    return 0;
}




目录
相关文章
|
Web App开发 JavaScript 关系型数据库
百度搜索:蓝易云【NodeJS 了解和快速入门 - 实现 http 服务 & 操作 mysql教程。】
通过使用上述示例代码,您可以快速入门并实现Node.js的HTTP服务和操作MySQL数据库。您可以根据需要进一步扩展和定制这些代码以满足您的具体要求。
116 0
|
8天前
|
人工智能 运维 安全
|
6天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
8天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
663 23
|
7天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。
|
14天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
1072 110
人工智能 数据可视化 数据挖掘
241 0