UVA 1473 Dome of Circus
https://cn.vjudge.net/problem/UVA-1473
题目
给出一些点,问包含这些点的最小圆锥(要求顶点在y轴,底面圆心在原点)的体积
题解
因为圆锥对称,所以可以把所有点旋转到xOy平面,然后问题转化成求最小的三角形。
于是我们就可以求出上凸包,然后最小的三角形显然过凸包上的一个或两个点
过一个点的时候可以推公式:
设$A(a,b),H(0,y),C(x,0)$
那么\[\frac{b}{x-a}=\frac{y}{x}\]
\[\pi x^2\times y/3 = C\times \frac{x^3}{x-a}\]
然后求导,得
\[\frac{3x^2(x-a)-x^3}{(x-a)^2}\]
符号只与分子有关
得$x=\frac{3a}{2}$时体积最小,其他时候体积都比这个大,偏得越多越大
然后还要考虑不能和上凸包的边相交
就这样就可以了,然后头晕写了个通过截面面积判断圆锥体积……
AC代码
#include<cstdio>
#include<cmath>
#include<cassert>
#include<algorithm>
#define REP(r,x,y) for(register int r=(x); r<(y); r++)
#define REPE(r,x,y) for(register int r=(x); r<=(y); r++)
#ifdef sahdsg
#define DBG(...) printf(__VA_ARGS__)
#else
#define DBG(...) void(0)
#endif
using namespace std; #define EPS 1e-10
int dcmp(const double &x) {
return fabs(x)<EPS?0:(x<0?-1:1);
}
inline double pf(double x) {
return x*x;
}
#define MAXN 10007
template <class T, int S>
struct array {
int n;
T arr[S];
T& operator[](int i) {return arr[i];}
};
struct dian {
double x,y;
bool operator<(const dian&r) const {
return x>r.x || (dcmp(x-r.x)==0 && y<r.y);
}
bool operator==(const dian&r) const {
return fabs(x-r.x)<EPS && fabs(y-r.y)<EPS;
}
} dots[MAXN], vec; dian operator-(const dian&a, const dian&b) {
return (dian){a.x-b.x,a.y-b.y};
} double Cross(const dian&l, const dian&r) {
return l.x*r.y-l.y*r.x;
} array<dian, MAXN> convex; int main() {
int n;
while(~scanf("%d", &n)) {
double x,y,z;
convex.n=0;
REP(i,0,n) {
scanf("%lf%lf%lf", &x, &y, &z);
dots[i].x=sqrt(pf(x)+pf(y));
dots[i].y=z;
}
sort(dots,dots+n);
n=unique(dots,dots+n)-dots;
REP(i,0,n) {
while(convex.n>=2 && dcmp(Cross(convex[convex.n-1]-convex[convex.n-2],dots[i]-convex[convex.n-2]))<=0) convex.n--;
convex[convex.n++]=dots[i];
}
double ans=2e33;
double r,h;
REP(i,0,convex.n) {
double tr,th,nans;
tr=convex[i].x*1.5; th=convex[i].y*3;
if(i>0 && dcmp(convex[i].y-convex[i-1].y)<=0) break;
if(i>0 && dcmp(Cross(convex[i]-convex[i-1],(dian){-tr,th}))<0) {
tr=Cross(convex[i],convex[i-1])/(convex[i-1].y-convex[i].y),
th=Cross(convex[i],convex[i-1])/(convex[i].x-convex[i-1].x);
}
else if(i<convex.n &&
dcmp(Cross(convex[i+1]-convex[i],(dian){-tr,th}))>0) {
tr=Cross(convex[i+1],convex[i])/(convex[i].y-convex[i+1].y),
th=Cross(convex[i+1],convex[i])/(convex[i+1].x-convex[i].x);
}
nans=tr*tr*th/2;
if(nans>EPS && nans<ans) {
ans=nans; r=tr; h=th;
}
}
printf("%.3f %.3f\n", h,r);
}
return 0;
}
UVA 1473 Dome of Circus的更多相关文章
- UVa 1473 - Dome of Circus 三分
把所有的点都映射到XOZ这个平面的第一象限内,则这个三维问题可以转化二维问题: 求一条直线,使所有点在这条直线的下方,直线与X轴和Z轴围成的三角形旋转形成的圆锥体积最小. 这样转化之后可以看出直线的临 ...
- 【凸包】【三分】Gym - 101309D - Dome of Circus
容易发现,圆锥体积和点的具体x.y坐标无关,只与其到z轴的距离sqrt(x*x+y*y)有关. 于是将这些三维的点都投射到二维的xOy平面的第二象限(sqrt(x*x+y*y),z),求个上凸壳,然后 ...
- HDU 3756 Dome of Circus
不会做,参见别人的程序: /* 底面为xy平面和轴为z轴的圆锥,给定一些点,使得圆锥覆盖所有点并且体积最小 点都可以投射到xz平面,问题转换为确定一条直线(交x,z与正半轴)使得与x的截距r 和与z轴 ...
- [HDU3756]Dome of Circus
题目大意: 在一个立体的空间内有n个点(x,y,z),满足z>=0. 现在要你放一个体积尽量小的圆锥,把这些点都包住. 求圆锥的高和底面半径. 思路: 因为圆锥里面是对称的,因此问题很容易可以转 ...
- HDU题解索引
HDU 1000 A + B Problem I/O HDU 1001 Sum Problem 数学 HDU 1002 A + B Problem II 高精度加法 HDU 1003 Maxsu ...
- hdu3756三分基础题
Dome of Circus Time Limit: 10000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- ACM ICPC 2010–2011, Northeastern European Regional Contest St Petersburg – Barnaul – Tashkent – Tbilisi, November 24, 2010
ACM ICPC 2010–2011, Northeastern European Regional Contest St Petersburg – Barnaul – Tashkent – Tbil ...
- uva 1354 Mobile Computing ——yhx
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGcAAANuCAYAAAC7f2QuAAAgAElEQVR4nOy9XUhjWbo3vu72RRgkF5
- UVA 10564 Paths through the Hourglass[DP 打印]
UVA - 10564 Paths through the Hourglass 题意: 要求从第一层走到最下面一层,只能往左下或右下走 问有多少条路径之和刚好等于S? 如果有的话,输出字典序最小的路径 ...
随机推荐
- NSwag.AspNetCore常用功能介绍
对于asp.net core 下的Swagger,之前一直用Swashbuckle的,因为官方推荐,再加上有老张的博客助力<从壹开始前后端分离[ .NET Core2.0/3.0 +Vue2.0 ...
- 松软科技web课堂:JavaScript If...Else 语句
条件语句用于基于不同条件执行不同的动作. 条件语句 在您写代码时,经常会需要基于不同判断执行不同的动作. 您可以在代码中使用条件语句来实现这一点. 在 JavaScript 中,我们可使用如下条件语句 ...
- CSS入门(定位之浮动定位、伪类之鼠标悬停、光标修改和透明度修改和列表样式)
一.定位 所为定位,实际上就是定义元素框相对于其正常位置,应该出现在哪儿 定位就是改变元素在页面上的默认位置 分类: 普通流定位(元素默认的定位方式) 浮动定位 相对定位 绝对定位 固定定位 1.普通 ...
- react学习之js-xlsx导入和导出excel表格
前记:最近真的挺忙的,一件事接着一件,都忘了我的React项目,尽管这是一个没写概率没写离散的夜晚,我决定还是先做做我的React 好了,进入正题 项目需求,需要导入和导出表单,发现前端已经强大到无所 ...
- 工具-Xmind常用快捷键/使用
1-快捷键 Ctrl+Shift+L 快捷键助手 Ctrl+Home 返回中心主题 Ctrl+] 插入摘要 Ctrl+I 插入图片 Ctrl+Shift+H 插入超链接 Ctrl+1,2,3,4,5, ...
- C语言入门-类型定义
一.自定义数据类型(typedef) c语言提供一个叫做typedef的功能来声明一个已有的数据类型的新名字,比如: typedef int length; 这样length成为了int类型的别名 这 ...
- orm终极大爆炸
orm终极 甩一个代码给你 # 创建字段 class Field: def __init__(self, name, column_type, primary_key, default): self. ...
- Java死锁演示
Java死锁演示 在线程中嵌套获取锁导致死锁.思路,尽量不要嵌套获取锁. package com.mozq.demo.demo; public class DeadLockDemo { private ...
- 使用脚本进行ansible批量主机的免密配置
应用场景: 在应用ansible的实际情况中,有一个很现实的问题,ansible是需要对主机做ssh免密登陆的,而挨个对主机做免密是非常的繁琐的,挨个敲IP不仅非常的繁琐而且容易出错,为解决这个问题, ...
- [Spring cloud 一步步实现广告系统] 8. 检索系统配置&依赖
工作流程 项目依赖 <dependencies> <!-- hystrix 监控面板 --> <dependency> <groupId>org.spr ...