Looksery Cup 2015-H. Degenerate Matrix(浮点数二分)
来源:互联网 发布:js清空页面内容 编辑:程序博客网 时间:2024/06/05 06:12
原题链接
The determinant of a matrix 2 × 2 is defined as follows:
A matrix is called degenerate if its determinant is equal to zero.
The norm ||A|| of a matrix A is defined as a maximum of absolute values of its elements.
You are given a matrix . Consider any degenerate matrix B such that norm ||A - B|| is minimum possible. Determine ||A - B||.
The first line contains two integers a and b (|a|, |b| ≤ 109), the elements of the first row of matrix A.
The second line contains two integers c and d (|c|, |d| ≤ 109) the elements of the second row of matrix A.
Output a single real number, the minimum possible value of ||A - B||. Your answer is considered to be correct if its absolute or relative error does not exceed 10 - 9.
1 23 4
0.2000000000
1 00 1
0.5000000000
假设矩阵的四个值为a, b, (第一行两个元素)c, d(第二行两个元素) , 二分枚举最大值mid, 那么a, b, c, d每个数都可以上下浮动mid, 算出a * d的最大值r1, 最小值l1, b * c的最大值r2, 最小值l2, 若[l1, r1]和[l2, r2]相交则可在最大值为mid之内构成一个B矩阵
#include <cstdio>#include <iostream>#define maxn 1005 #define MOD 1000000007typedef long long ll;using namespace std;int main(){ll a, b, c, d;scanf("%I64d%I64d%I64d%I64d", &a, &b, &c, &d);double l = 0, r = 2e9, a1, a2, b1, b2, c1, c2, d1, d2;for(int i = 0; i < 100000; i++){double mid = (l + r) / 2;a1 = a + mid, a2 = a - mid;b1 = b + mid, b2 = b - mid;c1 = c + mid, c2 = c - mid;d1 = d + mid, d2 = d - mid;double t1 = max(max(a1 * d1, a1 * d2), max(a2 * d1, a2 * d2));double t2 = min(min(a1 * d1, a1 * d2), min(a2 * d1, a2 * d2));double t3 = max(max(b1 * c1, b1 * c2), max(b2 * c1, b2 * c2));double t4 = min(min(b1 * c1, b1 * c2), min(b2 * c1, b2 * c2));if(t4 <= t1 && t2 <= t3) r = mid;else l = mid;}printf("%.9lf\n", l);return 0;}
- Looksery Cup 2015-H. Degenerate Matrix(浮点数二分)
- codeforces Looksery Cup 2015 H Degenerate Matrix 二分 注意浮点数陷阱
- codeforces Looksery Cup 2015 H Degenerate Matrix
- codeforce Looksery Cup 2015 H Degenerate Matrix
- Looksery Cup 2015 H. Degenerate Matrix
- [CodeForces] Looksery Cup 2015 H Degenerate Matrix 与二分时的精度控制
- Codeforces 549H. Degenerate Matrix 二分
- codeforces 549H Degenerate Matrix(二分)
- codeforces 549H H. Degenerate Matrix(二分+数学)
- Looksery Cup 2015 A
- Codeforces Looksery Cup 2015
- Looksery Cup 2015 Editorial
- Looksery Cup 2015
- Looksery Cup 2015
- Looksery Cup 2015 A B D G H
- Codeforces 549 H. Degenerate Matrix
- Looksery Cup 2015 B. Looksery Party
- Codeforces Looksery Cup 2015 B
- window 上部署sklearn(python+pip+numpy+scipy+matplotlib+sklearn)
- GOOGLE FQ插件
- 【DFS序】【线段树】【选派士兵】【noip模拟题】
- c++输入的几种方式
- 2016.11.10
- Looksery Cup 2015-H. Degenerate Matrix(浮点数二分)
- 原生JS获取当前浏览器版本以及版本号
- rocketmq源码分析(1)client模块--生产者的启动
- 关于格式化代码的方法
- 希腊字母读音及 Letex 写法
- 蓝桥杯 格子刷油漆
- 输出数据到txt文件(MATLAB)
- C——struct
- 《疯狂Android讲义》学习笔记 -- 使用Intent和IntentFilter进行通信