题目传送门(内部题86)


输入格式

第一行$n$
接下来$n$行,每行四个浮点数,分别表示变换前的坐标和变换后的坐标


输出格式

第一行浮点数$\theta$以弧度制表示
第二行浮点数$scale$
第三行两个浮点数$d_x,d_y$
我们将用$SPJ$以$10^{-3}$的绝对误差来判断变换结果是否正确,建议输出$10$位小数以上。


样例

样例输入1:

5
0 0 -1 1
0 1 -2 1
1 0 -1 2
1 1 0 0
2 1 1 0

样例输出1:

1.5707963268
1
-1 1

样例输入2:

5
0 0 1 1
0 1 1 2
1 0 2 1
1 1 0 0
2 1 1 0

样例输出2:

0
1
1 1


数据范围与提示

对于$30\%$的数据,保证存在可行的答案$\theta=0,scale=1$
对于另$30\%$的数据,$n\leqslant 500$
对于所有数据$n\leqslant 100,000$,坐标属于$[-10^9,10^9]$


题解

正解是随机化额……

不过还是有正确性的。

如果我们知道两组$(x_i,y_i)$,那么就可以解出$\theta,scale,d_x,d_y$了,然后将解出来的这四个值带入检验即可。

因为至少有一半是正确的,所以每次可以解出的概率就是$\frac{1}{4}$,解不出来的概率就是$\frac{3}{4}$,那么解$k$次,解不出来的概率就是$\frac{1}{4}^k$,$k=50$时概率已经$<10^{-5}$了。

对于官方题解里说的高斯消元,因为就两组,没有必要。

实在不行多交几遍(其实我就脸黑了……)

时间复杂度:$\Theta($玄学$)$。

期望得分:$100$分。

实际得分:$0\sim 100$分(脸黑别怪我)。


代码时刻

#include<bits/stdc++.h>
using namespace std;
const double eps=1e-5;
struct rec{double x0,y0,x2,y2;}e[100001];
pair<double,double> d[100001];
int n;
double dx,dy,Cos,Sin,scale,theta;
void solve(int x,int y)
{
double d1=e[x].x0-e[y].x0;
double d2=e[x].y0-e[y].y0;
double d3=e[x].x2-e[y].x2;
double d4=e[x].y2-e[y].y2;
double COS=(d1*d3+d2*d4)/(d1*d1+d2*d2);
double SIN=(d4-d2*COS)/d1;
theta=atan(SIN/COS);
dx=e[x].x2-e[x].x0*COS+e[x].y0*SIN;
dy=e[x].y2-e[x].x0*SIN-e[x].y0*COS;
Cos=cos(theta);
Sin=sin(theta);
scale=SIN/Sin;
if(scale<0.0)
{
theta+=M_PI;
Cos=cos(theta);
Sin=sin(theta);
scale=SIN/Sin;
}
}
bool judge()
{
int sum=0;
for(int i=1;i<=n;i++)
{
double nowx=e[i].x0*Cos-e[i].y0*Sin;
double nowy=e[i].x0*Sin+e[i].y0*Cos;
nowx=nowx*scale+dx;nowy=nowy*scale+dy;
if(fabs(nowx-e[i].x2)<eps&&abs(nowy-e[i].y2)<eps)sum++;
}
return (2*sum>=n);
}
int main()
{
srand(time(NULL));
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%lf%lf%lf%lf",&e[i].x0,&e[i].y0,&e[i].x2,&e[i].y2);
d[i]=make_pair(e[i].x2-e[i].x0,e[i].y2-e[i].y0);
}
sort(d+1,d+n+1);
int sum=0;
for(int i=1;i<=n;i++)
{
if(fabs(d[i].first-d[i-1].first)>eps||fabs(d[i].second-d[i-1].second)>eps)sum=0;
sum++;
if(2*sum>=n)
{
puts("0\n1");
printf("%.10lf %.10lf",d[i].first,d[i].second);
return 0;
}
}
while(1)
{
int x,y;
do
{
x=rand()%n+1;
y=rand()%n+1;
}while(x==y);
solve(x,y);
if(judge())
{
printf("%.10lf\n%.10lf\n%.10lf %.10lf",theta,scale,dx,dy);
return 0;
}
}
return 0;
}

rp++

[CSP-S模拟测试]:Walker(数学)的更多相关文章

  1. [考试反思]0729NOIP模拟测试10

    安度因:哇哦. 安度因:谢谢你. 第三个rank1不知为什么就来了.迷之二连?也不知道哪里来的rp 连续两次考试数学都占了比较大的比重,所以我非常幸运的得以发挥我的优势(也许是优势吧,反正数学里基本没 ...

  2. 0823NOIP模拟测试赛后总结

    考了两场感觉虚了... NOIP模拟测试30 分着考的. 就只有T2的美妙的暴力拿分了,60分rank10,挂了. T1是一道sb题,爆零了十分遗憾. 许多人都掉进了输出格式的坑里,C没大写.少个空格 ...

  3. Android单元测试与模拟测试详解

    测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...

  4. [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)

    目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...

  5. 安装nginx python uwsgi环境 以及模拟测试

    uwsgi帮助文档: http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html http://uwsgi-docs.re ...

  6. 【模拟】【数学】CSU 1803 2016 (2016湖南省第十二届大学生计算机程序设计竞赛)

    题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1803 题目大意: 给定n,m(n,m<=109)1<=i<=n,1& ...

  7. 利用Python中的mock库对Python代码进行模拟测试

    这篇文章主要介绍了利用Python中的mock库对Python代码进行模拟测试,mock库自从Python3.3依赖成为了Python的内置库,本文也等于介绍了该库的用法,需要的朋友可以参考下     ...

  8. 转 C#实现PID控制的模拟测试和曲线绘图

    C#实现PID控制的模拟测试和曲线绘图   本文分两部分,一部分是讲PID算法的实现,另一部分是讲如何用动态的曲线绘制出PID运算的结果. 首先,PID算法的理论模型请参考自动控制理论,最早出现的是模 ...

  9. Mockito:一个强大的用于Java开发的模拟测试框架

    https://blog.csdn.net/zhoudaxia/article/details/33056093 介绍 本文将介绍模拟测试框架Mockito的一些基础概念, 介绍该框架的优点,讲解应用 ...

随机推荐

  1. Tomcat使用时出现的问题总结

    1.有两种办法解决Tomcat启动时端口号冲突问题 1.第一种: 查看本地端口使用情况,找到被占用的8080端口,杀死该进程 1.查看本地端口命令:cmd->netstat -ano 2.找到 ...

  2. POJ - 1287 Networking (最小生成树&并查集

    You are assigned to design network connections between certain points in a wide area. You are given ...

  3. 树形DP水题系列(1):FAR-FarmCraft [POI2014][luogu P3574]

    题目 大意: 边权为1 使遍历树时到每个节点的时间加上点权的最大值最小 求这个最小的最大值 思路: 最优化问题 一眼树形DP 考虑状态设立 先直接以答案为状态 dp[u] 为遍历完以u为根的子树的答案 ...

  4. nrm切换npm的镜像

    安装node环境 npm -v 1. 安装nrm npm install nrm -g 2. 查看可选的镜像源 nrm ls 号代表目前使用的镜像源 3. 切换镜像源 现在将镜像源切换到淘宝为例 nr ...

  5. Codeforces 1215D. Ticket Game

    传送门 博弈,发现情况有点多,分析一下把有用的状态提取出来 显然各个位置的数字是没用的,我们只要知道两边的数字和分别是多少 并且状态显然和左右两边的 "?" 数量有关 因为最终我们 ...

  6. sql server 函数详解(1)字符串函数

    ASCII()函数 CHAR()函数 LEFT()函数 RIGHT()函数 LTRIM()函数 RTRIM()函数 STR()函数 字符串逆序的函数REVERSE() 计算字符串的长度函数LEN(st ...

  7. npm学习(十二)之高级用法

    如何使用距离标记标记包 如何使用双因素身份验证 如何使用安全令牌 如何从CLI更改配置文件设置 理解包和模块

  8. sql修改表名字段名

    修改字段: ALTER TABLE user_info CHANGE NAME name VARCHAR(10); 修改表名alter TABLE user_role RENAME user_info ...

  9. 搭建CocoaPods远程私有库

    1.创建自己的远程私有索引库,用来存放私有框架的.podspec文件,并将其添加到本地索引 我用的仓库是码云(https://gitee.com),用自己的账号新建一个私有仓库,我命名为Private ...

  10. Error:Unexpected lock protocol found in lock file. Expected 3, found 49.

    关于这个错误,今天研究了两三个小时的时间,查看网上的教程都解决不了问题,后来发现是自己的文件目录导入的有问题. 现在把自己关于解决这个问题的详细步骤说明一下. (1)首先,你先查看一下自己导入文件的目 ...