洛谷选题:P1888 三角函数

【题目】

输入一组勾股数 a,b,c,用分数格式输出其较小锐角的正弦值。(要求约分。)

输入格式

一行,包含三个正整数,即勾股数 a,b,c(无大小顺序)。

输出格式

一行,包含一个分数,即较小锐角的正弦值

输入样例:3 5 4

输出样例:3/5

【概念】

勾股数:就是直角三角形的三条边,其中斜边最长。

较小锐角的正弦值:就是三条边的最短边除以斜边。

【解题思路】

第一步:先找到三个数中的最大值和最小值

第二步:求这两个值的最大公约数s(可以用"欧几里得算法",具体可以看前面的文章"递归:利用欧几里得算法递归求最大公约数")

第三步:结果需要得到一个分数,所以假设最短边为x,最长边为y,输出为:(x/s)/(y/s)

【代码】

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
//利用欧几里得算法递归求两个数的最大公约数
int gcd(int x,int y)
{
    if(y==0)
        return x;
    else
        return gcd(y,x%y);
    
}
int main()
{

    int a[3];
    //第一步:输入直角三角形三条边
    for(int i=0;i<3;i++)
        cin>>a[i];//输入三个数
    sort(a,a+3);//对三个数从小到大排序
    //第二步:利用欧几里得算法求最大值a[2]和最小值a[0]的最大公约数
    int s=gcd(a[2],a[0]);
    //第三步:写正弦表达式的最简分数表示
    cout<<a[0]/s<<'/'<<a[2]/s;
    return 0;
}
相关推荐
房开民9 小时前
可变参数模板
java·开发语言·算法
t***5449 小时前
如何在现代C++中更有效地应用这些模式
java·开发语言·c++
不知名的忻9 小时前
Morris遍历(力扣第99题)
java·算法·leetcode·morris遍历
状元岐9 小时前
C#反射从入门到精通
java·javascript·算法
itman30110 小时前
C语言、C++与C#深度研究:从底层到现代开发演进全解析
c语言·c++·c·内存管理·编译模型
_深海凉_10 小时前
LeetCode热题100-除了自身以外数组的乘积
数据结构·算法·leetcode
Kk.080211 小时前
项目《基于Linux下的mybash命令解释器》(一)
前端·javascript·算法
SteveSenna11 小时前
Trossen Arm MuJoCo自定义1:改变目标物体
人工智能·学习·算法·机器人
Hical_W11 小时前
为 C++ Web 框架设计三层 PMR 内存池:从原理到实战
c++·github
yong999011 小时前
IHAOAVOA:天鹰优化算法与非洲秃鹫优化算法的混合算法(Matlab实现)
开发语言·算法·matlab