学堂在线C++语言程序设计基础(自主模式)第三章编程作业题

本文提供三道经典算法题目的解答方案,包括直角三角形判断、斐波那契数列生成及丑数验证,适用于初学者实践编程技能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C3-1 直角三角形 (100 满分)
题目描述
输入一个三角形的3边长度,判断该三角形是否为直角三角形,若是则输出True,若不是则输出False。推荐做法:定义一个函数,接受三个int参数,返回bool,再用主函数调用之。
输入描述
每行输入三个由空格隔开的整数 a, b, c ,表示三角形的 3 条边长
1 <= a,b ,c <= 10000
输出描述
对于每一行输入,输出True或者False表明是否为直角三角形
样例输入
3 4 5
6 7 8
1 1 1
样例输出
True
False
False

#include <iostream>
using namespace std;

int zhijiao(int a, int b,int c)
{
    bool t= true;
    bool f = false;
    if (a*a + b*b == c*c)   return t;
    else if (b*b + a*a == c*c)  return t;
    else if (c*c + a*a == b*b)  return t;
    else if (a*a + c*c == b*b)  return t;
    else if (c*c + b*b == a*a)  return t;
    else if (b*b + c*c == a*a)  return t;
    else  return f; 
}
int main()
{
    int a,b,c;
    cin >> a >> b >> c;
    if (zhijiao(a, b, c))
        cout << "True";
    else cout << "False";

    return 0;
}

C3-2 斐波那契数列 (100 满分)
题目描述
斐波那契数列f(n)满足以下定义:
f(0) = 1, f(1) = 1, f(n) = f(n-1) + f(n-2) (n >= 2)。
请用递归的方法编写函数,对于给定的n,求出斐波那契数列的第n项f(n)

输入描述
每行输入一个整数 n
0 <= n<= 30
输出描述
对于每一行输入,输出斐波那契数列第n项的值f(n)
样例输入
1
10
25
样例输出
1
89
121393

#include <iostream>
using namespace std;

int fib(int n)
{
    if (n == 1) return 1;
    if (n == 0) return 1;
    if (n >= 2) return (fib(n - 2) + fib(n - 1));
}
int main()
{
    int x, y;
    cin >> x;
    if (x >= 0 && x <= 30)
        y = fib(x);
    cout << y;
    return 0;
}

C3-3 丑数 (100 满分)
题目描述
只包含因子2,3,5的正整数被称作丑数,比如4,10,12都是丑数,而7,23,111则不是丑数,另外1也不是丑数。请编写一个函数,输入一个整数n,能够判断该整数是否为丑数,如果是,则输出True,否则输出False。
输入描述
每行输入一个正整数 n
1 <= n<= 1000000
输出描述
对于每一行输入,输出其是否为丑数,是则输出True,否则输出False

#include <iostream>
using namespace std;

bool choushu(int n)
{
    if (n <= 1) return false;
    while (n % 2 == 0)
        n /= 2;
    while (n % 3 == 0)
        n /= 3;
    while (n % 5 == 0)
        n /= 5;
    if (n == 1) return true;
    else return false;
}

int main()
{
    int n; 
    cin >> n;
    if (choushu(n))
    cout << "True";
    else cout << "False";
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值