hdu6206 Apple 2017icpc青岛赛区 java高精度类

http://acm.split.hdu.edu.cn/showproblem.php?pid=6206

题意:给出四个点,判断地四个点是否在其他三个点确定的圆内。

题解:确定圆心和半径。double有精度损失,所以用java的BigDecimal类。

设圆心(x,y),三个点(x1,y1),(x2,y2),(x3,y3).

有方程组:

(x1-x)^2+(y1-y)^2=(x2-x)^2+(y2-y)^2

(x3-x)^2+(y3-y)^2=(x2-x)^2+(y2-y)^2

化简得:

2*(x2-x1)*x+2*(y2-y1)*y=x2^2+y2^2-x1^2-y1^2

2*(x3-x2)*x+2*(y3-y2)*y=x3^2+y3^2-x2^2-y2^2

a1=2*(x2-x1),b1=2*(y2-y1),c1=x2^2+y2^2-x1^2-y1^2

a1=2*(x3-x2),b1=2*(y3-y2),c1=x3^2+y3^2-x2^2-y2^2

即:

a1*x+b1*y=c1

a2*x+b2*y=c2

所以有:

x=(c1*b2-c2*b1)/(a1*b2-a2*b1)

y=(a1*c2-a2*c1)/(a1*b2-a2*b1)

代码:

import java.util.*;  
import java.math.BigDecimal;  
  
public class Main {  
    public static void main(String[] argv) {  
        Scanner cin = new Scanner(System.in);  
        int n = cin.nextInt();  
        while (n != 0) {  
            n--;  
            BigDecimal[] x = new BigDecimal[5];  
            BigDecimal[] y = new BigDecimal[5];  
            //输入  
            for (int i = 1; i <= 4; i++) {  
                x[i] = cin.nextBigDecimal();  
                y[i] = cin.nextBigDecimal();  
            }  
            BigDecimal two = new BigDecimal(2);  
            BigDecimal a1,b1,c1,a2,b2,c2;  
            BigDecimal xx,yy,r,dis;  
            //计算a1,b1,c1,a2,b2,c2  
            a1=two.multiply(x[2].subtract(x[1]));  
            b1=two.multiply(y[2].subtract(y[1]));  
            c1=x[2].multiply(x[2]).add(y[2].multiply(y[2])).subtract(x[1].multiply(x[1]).add(y[1].multiply(y[1])));  
            a2=two.multiply(x[3].subtract(x[2]));  
            b2=two.multiply(y[3].subtract(y[2]));  
            c2=x[3].multiply(x[3]).add(y[3].multiply(y[3])).subtract(x[2].multiply(x[2]).add(y[2].multiply(y[2])));  
            //圆心及半径  
            xx=(c1.multiply(b2).subtract(c2.multiply(b1))).divide(a1.multiply(b2).subtract(a2.multiply(b1)));  
            yy=(a1.multiply(c2).subtract(a2.multiply(c1))).divide(a1.multiply(b2).subtract(a2.multiply(b1)));  
            r=(xx.subtract(x[1]).multiply(xx.subtract(x[1]))).add(yy.subtract(y[1]).multiply(yy.subtract(y[1])));  
            //第四点距圆心的距离  
            dis=(xx.subtract(x[4]).multiply(xx.subtract(x[4]))).add(yy.subtract(y[4]).multiply(yy.subtract(y[4])));  
            if(dis.compareTo(r)==1) {  
                System.out.println("Accepted");  
            }  
            else {  
                System.out.println("Rejected");  
            }  
        }  
    }  
}  


### 如何使用 Keil5 Hex 文件 对于仅拥有已编译好的 hex 文件而无源文件的情况,在 Keil V5 平台上直接hex 文件至单片机(如华大单片机)需采取特定的方法,因为直接调用该平台进行此类操作不可行[^1]。 #### 设置 Output 路径 进入 Keil 的 output 设置界面,指定要录的 hex 文件的具体位置。确保在路径输入框中填完整的 hex 文件名称并附带 `.hex` 扩展名;缺少此扩展名可能导致系统继续尝试录先前编译的结果而非所选的 hex 文件[^3]。 #### 配置 Flash 工具选项 针对不同类型的微控制器(MCU),可能还需调整 flash 下载工具的相关配置参数以匹配目标设备的要求。这一步骤通常涉及选择合适的编程算法以及设定通信接口等细节[^2]。 #### 启动下载过程 完成上述准备工作之后,可以通过点击调试窗口内的 “Download” 或者快捷菜单里的相应命令来启动实际的程序入流程。如果一切顺利的话,软件会自动连接硬件并将选定的 hex 数据传输到 MCU 中存储起来[^4]。 ```python # Python 示例代码用于说明自动化脚本概念 (并非真实实现) def download_hex_to_mcu(hex_file_path, mcu_type): """ 自定义函数模拟将 HEX 文件下载到指定型号的 MCU 上 参数: hex_file_path -- 完整路径字符串指向待上传的 .hex 文件 mcu_type -- 字符串表示的目标单片机类型标识符 返回值: 成功则返回 True ,失败抛出异常信息 """ try: configure_output_settings(hex_file_path) # 设定输出设置 select_flash_tool(mcu_type) # 挑选适合的闪存工具 execute_download_command() # 发送下载指令 return True # 表明成功结束 except Exception as e: raise RuntimeError(f"Failed to upload {hex_file_path}: {e}") ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值