Ball Dropping —— 1B
Ball Dropping
题目描述
给定一个上宽下窄的梯形,中间放一个半径为r的球,上底长为a,下底长为b,高为h,求球心到下底的距离。
范围
r,a,b,h≤1000,a>b
题解
思路1:二分一个长度带入验证
#include <bits/stdc++.h>
using namespace std;
const double eps = 1e-8;
double Fup (double a,double b) {
return sqrt(a * a + b * b);
}
double Fdown(double a,double b) {
return sqrt(a * a - b * b);
}
double c;//xiebian
double r,a,b,h;
bool check(double x) {
double rem = h - x;
double kx = Fup(a / 2,rem);
double ky = Fup(b / 2,x);
double some = Fdown(ky,r);
double all = Fup((a - b) / 2,h);
double other = Fdown(kx,r);
if(all - (some + other) < eps) return 1;
else return 0;
}
int main () {
cin >> r >> a >> b >> h;
if(2 * r < b) {
puts("Drop");
return 0;
}
double l = 0;double r = 2 * h + 1;
while (r - l > eps) {
double mid = (l + r) / 2;
if(check(mid)) r = mid;
else l = mid;
}
puts("Stuck");
printf("%.10lf\n",r);
return 0;
}
思路2:推公式
#include<cstdio>
#include<cmath>
using namespace std;
int main(){
double r,a,b,h;
scanf("%lf %lf %lf %lf",&r,&a,&b,&h);
if(2.0*r<b) puts("Drop");
else {
puts("Stuck");
double A=(a-b)/2.0,C=sqrt(h*h+A*A);
printf("%.10lf",r*A/C+(r*h/C-b/2.0)*h/A);
}
}
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· C# 13 中的新增功能实操
· Ollama本地部署大模型总结
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(4)
· langchain0.3教程:从0到1打造一个智能聊天机器人
· 用一种新的分类方法梳理设计模式的脉络