【NOI2018模拟】Yja

时间:2022-09-04 09:28:13

【NOI2018模拟】Yja

Description

  在平面上找\(n\)个点,要求这 \(n\)个点离原点的距离分别为 \(r1,r2,...,rn\) 。最大化这\(n\) 个点构成的凸包面积,凸包上的点的顺序任意。

  注意:不要求点全部在凸包上。

Input

  第一行一个整数 \(n\)。

  接下来一行$ n$ 个整数依次表示 \(ri\)。

Output

  输出一个实数表示答案,要求绝对误差或相对误差 \(≤ 10^{-6}\)。

Sample Input

4

5

8

58

85

Sample Output

2970

Hint

【数据范围与约定】

  对于前 \(20%\) 的数据,\(n ≤ 3\);

  对于前$ 40%$ 的数据,\(n ≤ 4\);

  对于另 \(20%\) 的数据,\(r1 = r2 = ... = rn\);

  对于 \(100%\) 的数据,\(1 ≤ n ≤ 8,1 ≤ ri ≤ 1000\)。

前置知识:拉格朗日乘数法:

https://blog.csdn.net/the_lastest/article/details/78136692

我们可以用\(\sum_{i=1}^n i!\)的复杂度枚举凸包的所有情况。因为肯定是选最长的\(i\)条线段,所以不需要\(2^i\)枚举集合。

题目中的几个偏导方程是:

\[\begin{align}
\theta _1+\theta_2+\dots+\theta_n=0\\
r_i*r_{i\%n+1}*cos(\theta _i)+\lambda=0\\
\end{align}
\]

由于\(cos(\theta)\)在\([-\pi,\pi]\)之间是单调递减的,所以我们可以二分\(\lambda\)然后反解出\(\theta_i\)并检验是否满足题意。

如果某个\(\theta_i\)与\(0\)非常接近就应该舍去。

代码:

#include<bits/stdc++.h>
#define ll long long
#define N 10
#define eps 1e-9 using namespace std;
inline int Get() {int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}while('0'<=ch&&ch<='9') {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}return x*f;} int n;
int r[N];
bool cmp(int a,int b) {return a>b;}
int st[N];
double val[N];
double ans; const double pi=acos(-1); double chk(int n,double ans) {
double tot=0;
for(int i=1;i<=n;i++) {
if(fabs(ans)>fabs(val[i])) {
exit(-1);
}
tot+=acos(-ans/val[i]);
}
if(tot>2*pi+eps) return 1;
else return 0;
} int q[N];
double solve(int n) {
double l,r,mid;
double ans=0;
while(1) {
for(int i=1;i<=n;i++) st[i]=::r[q[i]];
for(int i=1;i<n;i++) val[i]=st[i]*st[i+1];
val[n]=st[n]*st[1];
l=-1e9,r=1e9;
for(int i=1;i<=n;i++) {
l=max(l,-val[i]);
r=min(r,val[i]);
}
while(l+1e-5<r) {
mid=(l+r)/2.0;
if(chk(n,mid)) r=mid-eps;
else l=mid;
}
double now=0;
double angle_tot=0;
for(int i=1;i<=n;i++) {
double angle=acos(-l/val[i]);
if(angle<eps) now-=1e9;
angle_tot+=angle;
now+=val[i]*sin(angle);
}
ans=max(ans,now);
if(!next_permutation(q+1,q+1+n)) break;
}
return ans;
} int main() {
n=Get();
for(int i=1;i<=n;i++) r[i]=Get();
sort(r+1,r+1+n,cmp);
for(int i=3;i<=n;i++) {
for(int j=1;j<=i;j++) q[j]=j;
ans=max(ans,solve(i));
}
cout<<fixed<<setprecision(7)<<ans/2.0;
return 0;
}

【NOI2018模拟】Yja的更多相关文章

  1. 【NOI2018模拟5】三角剖分Bsh

    [NOI2018模拟5]三角剖分Bsh Description 给定一个正 n 边形及其三角剖分,共 2n - 3 条边 (n条多边形的边和n-3 条对角线),每条边的长度为 1. 共 q 次询问,每 ...

  2. JZOJ 5602&period;【NOI2018模拟3&period;26】Cti

    JZOJ 5602.[NOI2018模拟3.26]Cti Description 有一个 \(n×m\) 的地图,地图上的每一个位置可以是空地,炮塔或是敌人.你需要操纵炮塔消灭敌人. 对于每个炮塔都有 ...

  3. 【JZOJ5605】【NOI2018模拟3&period;26】Arg

    题目描述 给出一个长度为 m 的序列 A, 请你求出有多少种 1...n 的排列, 满足 A 是它的一个 LIS. 解题思路 如何求出一个序列的LIS? 对于二分的方法,每次插入一个数,将它放到第一个 ...

  4. 【JZOJ5603】【NOI2018模拟3&period;27】Xjz

    题目描述 给定字符串 S 和 T. 串A和串B匹配的定义改为:存在一个字符的映射,使得A应用这个映射之后等于B,且这个映射必须为一个排列. A=121, B=313,当映射为{1->3, 2-& ...

  5. BSOJ5458 &lbrack;NOI2018模拟5&rsqb;三角剖分Bsh 分治最短路

    题意简述 给定一个正\(n\)边形及其三角剖分,每条边的长度为\(1\),给你\(q\)组询问,每次询问给定两个点\(x_i\)至\(y_i\)的最短距离. 做法 显然正多边形的三角剖分是一个平面图, ...

  6. NOIP2018 模拟赛(二十二)雅礼NOI

    Preface 这次的题目都是NOI+的题,所以大家的分数都有点惨烈. 依靠T1大力骗分水到Rank2 所以想看正解的话看这里吧 A. 「雅礼NOI2018模拟赛(一) Day1」树 看一眼题目感觉十 ...

  7. 【XSY2968】线性代数

    题目来源:noi2018模拟测试赛(二十二) 毒瘤板题+提答场……真tm爽 提答求最大团,各路神仙退火神仙随机化八仙过海 题意: 题解: 支持双端插入的回文自动机板题 代码: #include< ...

  8. 【XSY2892】【GDSOI2018】谁是冠军

    题目来源:noi2018模拟测试赛(二十三)T3 san 为什么noi模拟赛里会做到省选原题啊…… 题意: Description 有n个人,简单起见把他们编号为1到n,每个人有三项指标分别是攻击力, ...

  9. 【XSY2989】字符串

    题目来源:NOI2018模拟测试赛(二十六) 题解: 首先由于这是个01串,所以反对称串的意思就是这个字符串的后半部分是前半部分的反转且翻转结果: 一个串出现有三种情况:在前半部分,在后半部分或穿过中 ...

随机推荐

  1. 《JavaScript Ninja》之挥舞函数

    挥舞函数 匿名函数为什么如此重要 通常使用匿名函数的情况是,创建一个供以后使用的函数.例如,将匿名函数保存在一个变量里,将其作为一个对象的方法,或者是将匿名函数作为一个回调.-->在这些情况下, ...

  2. zoj3261 带权并查集

    题意:有很多颗星球,各自有武力值,星球间有一些联系通道,现在发生战争,有一些联系通道会被摧毁,而一些星球会通过还没有被摧毁的联系通道直接或者间接联系能够联系到的武力值最高的星球求救,如果有多个武力值都 ...

  3. WCF Rest Json

    1.定义ServiceContract及实现 [ServiceContract] public interface IMemberService { [OperationContract] strin ...

  4. linux 日志查看总结

    1 grep "ERROR" catalina.log -a 20 -b 10 查看 catalina.log 中error的唯一 一行的后20行 前10行这种情况一般要唯一确定. ...

  5. C&num;秘密武器之扩展方法

    原文:C#秘密武器之扩展方法 为何要用扩展方法? 作为一个.NET程序猿,我们经常要跟.net自带类库或者第三方dll类库打交道,有时候我们未必能够通过反编译来查看它们的代码,但是我们通常需要给它们扩 ...

  6. 一步到位分布式开发Zookeeper实现集群管理

    说到分布式开发Zookeeper是必须了解和掌握的,分布式消息服务kafka .hbase 到hadoop等分布式大数据处理都会用到Zookeeper,所以在此将Zookeeper作为基础来讲解. Z ...

  7. PIC单片机基础2

    PIC中档系列单片机,每条指令14位,共有35条汇编指令,根据操作对象不同,可将其分为三类: 字节操作类指令 位操作类指令 立即数与控制类操作指令 1.字节操作类指令,以MOVF指令为例: 指令:MO ...

  8. 关于概率dp的HINT

    摘自shadowice1984的blog 这里想讲一个关于概率题的小技巧,就是关于如何求某个事件发生的概率PP,事实上大家也清楚,除了一些特殊的近似算法之外,我们在程序中计算概率的方法无非就是加减乘除 ...

  9. python之django基础

    看了不是同一期的视频,发现9期老师线性引入的方式,讲得django更加易于理解掌握. 抱歉的是,笔记没有整理就发上来了.希望看到的人不要被我带偏. 1. 新建Django项目 命令行创建: djang ...

  10. python3 tkinter添加图片和文本

    在前面一篇文章基础上,使用tkinter添加图片和文本.在开始之前,我们需要安装Pillow图片库. 一.Pillow的安装 1.方法一:需要下载exe文件,根据下面图片下载和安装       下载完 ...