jzoj 3660. 【SHTSC2014】信号增幅仪

2024-01-30 05:38

本文主要是介绍jzoj 3660. 【SHTSC2014】信号增幅仪,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Description

无线网络基站在理想状况下有效信号覆盖范围是个圆形。而无线基站的功耗与圆的半径的平方成正比。现给出平面上若干网络用户的位置,请你选择一个合适的位置建设无线基站 ……
就在你拿起键盘准备开始敲代码的时候,你的好朋友发明家SHTSC突然出现了。SHTSC刚刚完成了他的新发明——无线信号增幅仪。增幅仪能够在不增加无线基站功耗的前提下,使得有效信号的覆盖范围在某一特定方向上伸长若干倍。即:使用了增幅仪的无线基站覆盖范围是个椭圆,其功耗正比于半短轴长的平方。
现给出平面上若干网络用户的位置,请你选择一个合适的位置建设无线基站,并在增幅仪的帮助下使所有的用户都能接收到信号,且无线基站的功耗最小。
注意:由于SHTSC增幅仪的工作原理依赖地磁场,增幅的方向是恒定的。

Input

第一行一个整数:n。平面内的用户个数。
之后的n行每行两个整数x, y,表示一个用户的位置。
第n+2行一个整数:a。表示增幅仪的增幅方向,单位是度。表示增幅仪的方向是从x正方向逆时针转a度。
第n+3行一个整数:p。表示增幅仪的放大倍数。

Output

输出一行一个实数,为能够覆盖所有用户的最小椭圆的半短轴长,四舍五入到三位小数。

Sample Input

输入1:
2
1 0
-1 0
0
2
输入2:
3
1 1
-1 -1
0 0
45
7

Sample Output

输出1:
0.500
输出2:
0.202

Data Constraint

对于10%的数据,保证最优方案的中心在原点。
对于20%的数据,保证点是随机生成的。
对于30%的数据,n≤100。
对于50%的数据,n≤5000。
对于100%的数据,n≤50000,0≤a<180,1≤p≤100,|x|,|y|≤2×10^8。


Sulotion

因为只有固定的方向才能增幅,而结果为椭圆,于是我们可以把它缩放为增幅前的圆,
所以先旋转a度(用三角函数要转弧度),然后每个点横坐标除以p,最后最小圆覆盖。
最小圆覆盖的方法:随机增量法 http://blog.csdn.net/commonc/article/details/52291822(非常详细且证明了时间复杂度期望为O(n))
及已知三点求外接圆的方法 http://blog.csdn.net/liyuanbhu/article/details/52891868

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;#define N 50050
#define DB double
#define pi 3.1415926535897932384626433832795struct note
{DB x,y;
};note a[N];
DB al,th,p,co,si,ans,s;
int n; DB sqr(DB x){return x*x;}
DB dis(note x,note y){return sqrt(sqr(x.x-y.x)+sqr(x.y-y.y));}
bool pd(int x) {return dis(a[0],a[x])<=s;} void init()
{scanf("%d",&n);int x,y;for (int i=1;i<=n;i++){scanf("%d%d",&x,&y);a[i].x=DB(x); a[i].y=DB(y);}scanf("%d%d",&x,&y);al=DB(x); p=DB(y);th=al*pi/180.00000;si=sin(th); co=cos(th);DB xx,yy;for (int i=1;i<=n;i++){xx=a[i].x; yy=a[i].y;a[i].x=si*yy+co*xx;a[i].y=co*yy-si*xx;a[i].x/=p;}
}note solve(note x,note y,note z)
{DB a,b,c,d,e,f;a=x.x-y.x; b=x.y-y.y; c=x.x-z.x; d=x.y-z.y;e=sqr(x.x)-sqr(y.x)+sqr(x.y)-sqr(y.y);  e/=2;f=sqr(x.x)-sqr(z.x)+sqr(x.y)-sqr(z.y);  f/=2;note re;re.x=-(d*e-b*f)/(b*c-a*d);re.y=-(a*f-c*e)/(b*c-a*d);return re;
}void find()
{random_shuffle(a+1,a+n+1);for (int i=1;i<=n;i++)if (pd(i)==false){a[0]=a[i]; s=0.0;for (int j=1;j<=i-1;j++)if (pd(j)==false){a[0].x=(a[i].x+a[j].x)/2; a[0].y=(a[i].y+a[j].y)/2;s=dis(a[i],a[j])/2;for (int k=1;k<=j-1;k++)if (pd(k)==false){a[0]=solve(a[i],a[j],a[k]);s=dis(a[0],a[i]);}}}
}int main()
{freopen("amplifier.in","r",stdin);freopen("amplifier.out","w",stdout);init();find();ans=s;printf("%.3lf\n",ans);return 0;
}

这篇关于jzoj 3660. 【SHTSC2014】信号增幅仪的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/659247

相关文章

【操作系统】信号Signal超详解|捕捉函数

🔥博客主页: 我要成为C++领域大神🎥系列专栏:【C++核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 ​ 如何触发信号 信号是Linux下的经典技术,一般操作系统利用信号杀死违规进程,典型进程干预手段,信号除了杀死进程外也可以挂起进程 kill -l 查看系统支持的信号

DDS信号的发生器(验证篇)——FPGA学习笔记8

前言:第一部分详细讲解DDS核心框图,还请读者深入阅读第一部分,以便理解DDS核心思想 三刷小梅哥视频总结! 小梅哥https://www.corecourse.com/lander 一、DDS简介         DDS(Direct Digital Synthesizer)即数字合成器,是一种新型的频率合成技术,具有低成本、低功耗、高分辨率、频率转换时间短、相位连续性好等优点,对数字信

[FPGA][基础模块]跨时钟域传播脉冲信号

clk_a 周期为10ns clk_b 周期为34ns 代码: module pulse(input clk_a,input clk_b,input signal_a,output reg signal_b);reg [4:0] signal_a_widen_maker = 0;reg signal_a_widen;always @(posedge clk_a)if(signal_a)

将一维机械振动信号构造为训练集和测试集(Python)

从如下链接中下载轴承数据集。 https://www.sciencedirect.com/science/article/pii/S2352340918314124 import numpy as npimport scipy.io as sioimport matplotlib.pyplot as pltimport statistics as statsimport pandas

防止在 Qt 中触发信号

在 Qt 中工作时,有时我们需要暂时阻止某些信号的触发。以下是一个经典场景:我们有一个 QCheckBox 对象,当用户勾选或取消勾选时,需要调用一个函数,因此我们将这个函数连接到 stateChanged(int state) 信号。然而,在某些条件下,我们在代码中更改 QCheckBox 的状态,这会导致触发不需要的信号。那么如何在特定情况下防止信号触发呢? 使用 clicked 信号 如

Simple-STNDT使用Transformer进行Spike信号的表征学习(一)数据处理篇

文章目录 1.数据处理部分1.1 下载数据集1.2 数据集预处理1.3 划分train-val并创建Dataset对象1.4 掩码mask操作 数据、评估标准见NLB2021 https://neurallatents.github.io/ 以下代码依据 https://github.com/trungle93/STNDT 原代码使用了 Ray+Config文件进行了参数搜

QT事件处理系统之三:子类化QPushButton后,对事件进行相应处理后,自定义按钮无法发出clicked信号的问题

1、信号槽绑定 如下,Widget中进行了SelfButton按钮的信号槽绑定。 Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget){ui->setupUi

【Qt笔记①】帮助文档、窗口、按钮、信号和槽、lambda表达式

学习第一天:2024-3-9 文章目录 Qt creator 快捷键帮助文档默认生成的main.cpp逐行解释核心类帮助文档的查阅方法-①代码创建按钮第一个第二个对窗口的其他设置 对象树窗口坐标系信号和槽(优点:松散耦合)帮助文档的查阅方法-②找信号函数的方法找槽函数的方法 自定义信号和槽 lambda表达式练习MenuTool Qt creator 快捷键 运行:ctrl

【七】【QT开发应用】跨UI发送信号,跨线程发送信号

跨UI发送信号 基本框架 新建窗口 自定义信号 跨线程发送信号 新建线程 查看线程号 完整代码 跨UI发送信号 setdialog.h #ifndef SETDIALOG_H#define SETDIALOG_H#include <QDialog>namespace U

使用 C++11 Lambda 表达式在 Qt 中连接信号与槽

在 Qt 使用 C++11 引入的 lambda 表达式来简化信号与槽的连接已经成为一种不错的选择。本文将通过一个简单的例子来展示如何使用 lambda 表达式来连接 QAction 的信号与槽。 传统的连接方式 首先,看看传统的连接方式: QAction* action = foo->addAction(tr("Some Action"));connect(action, SIGNAL(