【2024蓝桥杯/C++/B组/小球反弹】

题目

分析

Sx = 2 * k1 * x;

Sy = 2 * k2 * y; (其中k1, k2为整数)

Vx * t = Sx;

Vy * t = Sy;

k1 / k2 = (15 * y) / (17 * x);

目标1:根据k1与k2的关系,找出一组最小整数组(k1, k2)(为什么最小?因为题目求第一次返回!这实际上是一个循环过程!)

目标2:求出Sx,Sy,再根据勾股定理求S

代码

cpp 复制代码
#include<bits/stdc++.h> // 引入所有的标准库头文件
using namespace std; // 使用标准命名空间 std 中的标识符

// 定义常量 x 和 y 的值
const int x = 343720;
const int y = 233333;

int main()
{
    // 计算 k1 和 k2 的值,k1 等于 15 乘以 y,k2 等于 17 乘以 x
    int k1 = 15*y, k2 = 17*x;
    
    // 计算 k1 和 k2 的最大公约数,并将其赋值给 gcd
    int gcd = __gcd(k1, k2);
    
    // 将 k1 和 k2 分别除以它们的最大公约数
    k1 /= gcd, k2 /= gcd;

    // 计算 sx 的值,sx 等于 2 乘以 k1 乘以 x
    double sx = 2*k1*x;
    
    // 计算 sy 的值,sy 等于 2 乘以 k2 乘以 y
    double sy = 2*k2*y;
    
    // 根据勾股定理计算 s 的值
    double s = sqrt(sx*sx + sy*sy);

    // 输出 s 的值,保留两位小数
    printf("%.2f", s);

    // 返回 0,表示程序正常结束
    return 0;
}
相关推荐
獭.獭.16 分钟前
C++ -- STL【unordered_set和unordered_map的使用】
c++·stl·unordered_map·unordered_set
star _chen1 小时前
C++ std::move()详解:从小白到高手
开发语言·c++
福尔摩斯张1 小时前
C++核心特性精讲:从C语言痛点出发,掌握现代C++编程精髓(超详细)
java·linux·c语言·数据结构·c++·驱动开发·算法
charlie1145141912 小时前
如何快速在 VS2026 上使用 C++ 模块 — 完整上手指南
开发语言·c++·笔记·学习·现代c++
报错小能手2 小时前
STL_unordered_map
开发语言·c++·哈希算法
历程里程碑3 小时前
C++ 9 stack_queue:数据结构的核心奥秘
java·开发语言·数据结构·c++·windows·笔记·算法
仰泳的熊猫3 小时前
1108 Finding Average
数据结构·c++·算法·pat考试
AA陈超4 小时前
虚幻引擎5 GAS开发俯视角RPG游戏 P07-18.生成火球术
c++·游戏·ue5·游戏引擎·虚幻
wxin_VXbishe4 小时前
springboot居家养老管理系统-计算机毕业设计源码55953
java·c++·spring boot·python·spring·django·php
ULTRA??4 小时前
归并排序算法实现,kotlin,c++,python
c++·python·kotlin