给出的数据1e12规模,常规判点是否在圆范围内肯定要用到半径,求得过程中无法避免溢出,因此用JAVA自带的浮点大数运算,和个ZZ一样比赛中eclipse出现问题,而且太久没写JAVA语法都不清楚变量忘了申请空间/构造,还不知道为什么写不了类/函数,一个一个把运算符改成JAVA大数对象封装的函数,括号看的头疼,太傻了,应该交给IDE正常的队友写的,而且也没什么难度,JAVA大数还不用考虑什么精度,怎么简单怎么来。

import java.io.*;
import java.math.*;
import java.util.*;
import java.util.concurrent.atomic.DoubleAdder;
import java.util.zip.ZipEntry; import org.omg.PortableInterceptor.DISCARDING; public class Main {
public static BigDecimal dis(BigDecimal ax, BigDecimal ay, BigDecimal bx, BigDecimal by){
BigDecimal res = ((ax.subtract(bx)).multiply(ax.subtract(bx))).add((ay.subtract(by)).multiply(ay.subtract(by)));
return res;
}
public static BigDecimal R(BigDecimal ax, BigDecimal ay, BigDecimal bx, BigDecimal by, BigDecimal cx, BigDecimal cy) {
BigDecimal pa = by.subtract(cy);
BigDecimal pb = cy.subtract(ay);
BigDecimal pc = ay.subtract(by);
BigDecimal PA = ax.multiply(pa);
BigDecimal PB = bx.multiply(pb);
BigDecimal PC = cx.multiply(pc);
return PA.add(PB.add(PC));
}
public static BigDecimal Ux(BigDecimal ax, BigDecimal ay, BigDecimal bx, BigDecimal by, BigDecimal cx, BigDecimal cy){
BigDecimal pa = by.subtract(cy);
BigDecimal pb = cy.subtract(ay);
BigDecimal pc = ay.subtract(by);
BigDecimal PA = ((ax.multiply(ax)).add((ay.multiply(ay)))).multiply(pa);
BigDecimal PB = ((bx.multiply(bx)).add((by.multiply(by)))).multiply(pb);
BigDecimal PC = ((cx.multiply(cx)).add((cy.multiply(cy)))).multiply(pc);
return PA.add(PB.add(PC));
}
public static BigDecimal Uy(BigDecimal ax, BigDecimal ay, BigDecimal bx, BigDecimal by, BigDecimal cx, BigDecimal cy){
BigDecimal pa = cx.subtract(bx);
BigDecimal pb = ax.subtract(cx);
BigDecimal pc = bx.subtract(ax);
BigDecimal PA = ((ax.multiply(ax)).add((ay.multiply(ay)))).multiply(pa);
BigDecimal PB = ((bx.multiply(bx)).add((by.multiply(by)))).multiply(pb);
BigDecimal PC = ((cx.multiply(cx)).add((cy.multiply(cy)))).multiply(pc);
return PA.add(PB.add(PC));
}
public static void main(String[] args) {
int T;
Scanner cin = new Scanner((new BufferedInputStream(System.in)));
BigDecimal[] a = new BigDecimal[2];
BigDecimal[] b = new BigDecimal[2];
BigDecimal[] c = new BigDecimal[2];
BigDecimal[] z = new BigDecimal[2];
BigDecimal r = null;
BigDecimal x = null;
BigDecimal y = null;
BigDecimal dd = null;
BigDecimal eps = BigDecimal.valueOf(1e-20);
T = cin.nextInt();
for(int i = 0; i < T; i++)
{
a[0] = cin.nextBigDecimal(); a[1] = cin.nextBigDecimal();
b[0] = cin.nextBigDecimal(); b[1] = cin.nextBigDecimal();
c[0] = cin.nextBigDecimal(); c[1] = cin.nextBigDecimal();
z[0] = cin.nextBigDecimal(); z[1] = cin.nextBigDecimal();
BigDecimal D = R(a[0], a[1], b[0], b[1], c[0], c[1]).multiply(BigDecimal.valueOf(2));
x = Ux(a[0], a[1], b[0], b[1], c[0], c[1]).divide(D);
y = Uy(a[0], a[1], b[0], b[1], c[0], c[1]).divide(D);
//System.out.println(x+" "+y);
r = dis(a[0], a[1], x, y);
dd = dis(z[0], z[1], x, y);
//System.out.println(r+" "+dd);
if(dd.subtract(r).compareTo(eps) > 0)
System.out.println("Accepted");
else
System.out.println("Rejected"); }
}
}

HDU 6206 青岛网络赛1001 高精度 简单几何的更多相关文章

  1. 16年青岛网络赛 1001 I Count Two Three

    题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1001&cid=723 I Count Two ThreeTi ...

  2. HDU 4759 Poker Shuffle(2013长春网络赛1001题)

    Poker Shuffle Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  3. HDU 4738 Caocao's Bridges (2013杭州网络赛1001题,连通图,求桥)

    Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  4. HDU 5880 Family View (2016 青岛网络赛 C题,AC自动机)

    题目链接  2016 青岛网络赛  Problem C 题意  给出一些敏感词,和一篇文章.现在要屏蔽这篇文章中所有出现过的敏感词,屏蔽掉的用$'*'$表示. 建立$AC$自动机,查询的时候沿着$fa ...

  5. HDU 6212 Zuma 2017青岛网络赛 区间DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6212 解法:看了眼题就发现这个BZOJ 1032不是一毛一样?但是BZOJ上那是个巨坑,数据有错,原来 ...

  6. HDU 6215 2017Brute Force Sorting 青岛网络赛 队列加链表模拟

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6215 题意:给你长度为n的数组,定义已经排列过的串为:相邻两项a[i],a[i+1],满足a[i]&l ...

  7. hdu 5881 Tea (2016 acm 青岛网络赛)

    原题地址:http://acm.hdu.edu.cn/showproblem.php?pid=5881 Tea Time Limit: 3000/1000 MS (Java/Others)    Me ...

  8. HDU 5884 Sort(2016年青岛网络赛 G 二分+贪心+小优化)

    好题 题意:给你n<=100000个数,每个数范围[0,1000],然后给你一个最大的代价T,每次最多合并k个数成为一个数,代价为k个数的总和.问最后合成1个数的总代价不大于T的最小k 题解:我 ...

  9. HDU 5886 Tower Defence(2016青岛网络赛 I题,树的直径 + DP)

    题目链接  2016 Qingdao Online Problem I 题意  在一棵给定的树上删掉一条边,求剩下两棵树的树的直径中较长那的那个长度的期望,答案乘上$n-1$后输出. 先把原来那棵树的 ...

随机推荐

  1. 软件工程-东北师大站-第五次作业(PSP)

    1.本周PSP 2.本周进度条 3.本周累计进度图 代码累计折线图 博文字数累计折线图 4.本周PSP饼状图

  2. Python学习之路6 - 装饰器

    装饰器 定义:本质是函数,(装饰其他函数)就是为其他函数添加附加功能.原则:1.不能修改被装饰的函数的源代码 2.不能修改被装饰的函数的调用方式 实现装饰器的知识储备: 1.函数即“变量” 2.高阶函 ...

  3. Android连接SQLServer详细教程(数据库+服务器+客户端)

    摘星 标签: android连接sql http://blog.csdn.net/haoxingfeng/article/details/9111105

  4. FivePlus——分工理解

    最终的游戏方案 游戏采用回合制,每回合双方英雄各自轮流选择移动和攻击以及大招,选择结束进行结算 英雄/小兵/塔的攻击力/大招效果参照作业要求,如果发现不均衡再进行调整 UI界面考虑使用QT或者命令行界 ...

  5. Java微笔记(9)

    使用 Date 和 SimpleDateFormat 类表示时间 处理日期和时间的相关数据,可以使用 java.util 包中的 Date 类 使用 Date 类的默认无参构造方法创建出的对象就代表当 ...

  6. Java微笔记(8)

    Java 中的包装类 Java 为每个基本数据类型都提供了一个包装类,这样就可以像操作对象那样来操作基本数据类型 基本类型和包装类之间的对应关系: 包装类主要提供了两大类方法: 将本类型和其他基本类型 ...

  7. css3浏览器私有属性前缀使用详解

    什么是浏览器私有属性前缀 CSS3的浏览器私有属性前缀是一个浏览器生产商经常使用的一种方式.它暗示该CSS属性或规则尚未成为W3C标准的一部分. 以下是几种常用前缀 -webkit- -moz- -m ...

  8. 初识ES6 解构

    1.数组的解构 ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构 例子: let [a, b, c] = [1, 2, 3]; console.log(a);//1cons ...

  9. 3dContactPointAnnotationTool开发日志(三四)

      今天就是让背景图可以变大变小,变透明度,然后将3d的点投影到图片上,输出2d接触点信息:   可以看到输出了正确的接触点信息:   然后还把空物体的包围盒大小设置为边长为0.1的的正方体,点击选中 ...

  10. Cobbler环境搭建

    Cobbler服务器系统: CentOS 6.6 64位Cobbler版本: cobbler-2.6.11IP地址:192.168.166.136 1.安装epel库 rpm -ivh http:// ...