2013编程之美全国挑战赛第二场-集会

简介:

昨天做编程之美的题感觉只有这一道是水题。思路没问题但是写程序写错了一个地方没AC。今天翻出来想了一下终于解决了。

解题思路:

要寻找的这个目标点的纵坐标为0,设横坐标为x。以示例数据为例,可以得到目标点到这些点的距离,更直观一点,绘制成图形点击查看。观察可知符合要求的点可能出现的位置是某两个抛物线的交点或者某个抛物线的顶点。求出这些点来比较计算出的距离,取最小的即可。没机会提交的代码如下:


import java.util.Scanner;  

public class Main {  
    public static void main(String[] args) {  
        Scanner in = new Scanner(System.in);  
        int T = in.nextInt();// T个测试  
        for (int t = 0; t < T; t++) {  
            int N = in.nextInt();  
            int x[] = new int[N];  
            int y[] = new int[N];  
            for (int i = 0; i < N; i++) {  
                x[i] = in.nextInt();  
                y[i] = in.nextInt();  
            }  
            double min = Double.MAX_VALUE;  
            double ret = 0;  
            for (int i = 0; i < N; i++) {  
                for (int j = i + 1; j < N; j++) {  
                    double d = 0.5  
                            * (sq(x[i]) - sq(x[j]) + sq(y[i]) - sq(y[j]))  
                            / (x[i] - x[j]);  
                    double res = calc(x, y, d);  
                    if (res < min) {  
                        min = res;  
                        ret = d;  
                    }  
                }  
            }  
            for (int i = 0; i < N; i++) {  
                double d = x[i];  
                double res = calc(x, y, d);  
                if (res < min) {  
                    min = res;  
                    ret = d;  
                }  
            }  
            System.out.println("Case #" + (t + 1) + ": " + ret);  
        }  
    }  

    public static int sq(int x) {  
        return x * x;  
    }  

    public static double sq(double x) {  
        return x * x;  
    }  

    public static double calc(int[] x, int[] y, double d) {  
        double max = 0.0;  
        for (int i = 0; i < x.length; i++) {  
            double temp = sq(x[i] - d) + sq(y[i]);  
            if (temp > max)  
                max = temp;  
        }  
        return max;  
    }  
}

目录
相关文章
|
3月前
|
数据采集 人工智能 算法
近五千支队伍决战AI之巅, AFAC2024金融智能创新大赛在2024 Inclusion · 外滩大会完美收官
自从2022年12月ChatGPT上线以来,全球掀起了一场你追我赶的AI竞赛,不少国家都在全力以赴,抢占制高点。
|
5月前
|
数据采集 存储 机器学习/深度学习
【Mathorcup杯大数据挑战赛复赛 A题 二手车估价】复赛思路及Python实现
Mathorcup杯大数据挑战赛复赛A题“二手车估价”问题的解题思路和Python实现,包括数据预处理、特征工程、模型训练和预测结果的存储,主要使用了LightGBM模型进行交易周期的预测。
72 4
|
5月前
|
机器学习/深度学习 数据采集 算法
【 2021 MathorCup杯大数据挑战赛 A题 二手车估价】初赛复赛总结、方案代码及论文
总结了2021 MathorCup杯大数据挑战赛A题“二手车估价”的初赛和复赛经验,包括题目要求、解题思路、所用方法和结果,提供了详细的数据分析、模型构建、论文撰写和工具使用技巧,并展示了初赛和复赛的论文。
96 2
时隔4年再夺金奖!北大斩获「编程奥林匹克」亚军,刷新队史最高排名
时隔4年再夺金奖!北大斩获「编程奥林匹克」亚军,刷新队史最高排名
199 0
|
算法
2021-2022年度第三届全国大学生算法设计与编程挑战赛(秋季赛)热身赛 B.这是一道大水题(树状数组)
2021-2022年度第三届全国大学生算法设计与编程挑战赛(秋季赛)热身赛 B.这是一道大水题(树状数组)
169 0
2021-2022年度第三届全国大学生算法设计与编程挑战赛(秋季赛)热身赛 B.这是一道大水题(树状数组)
|
机器学习/深度学习 人工智能 算法
四所中国高校夺冠三大赛道,这场24个国家2500多支队伍角逐的算法竞赛刚刚落幕
可以「欺骗」神经网络的对抗样本是近期计算机视觉,以及机器学习领域的热门研究方向。为了让 AI 能够抵御攻击,研究人员一直在寻找构建稳固机器学习算法的道路。最近,在国际顶级人工智能大会 IJCAI 上,一场有关人工智能安全的攻防战落下了帷幕。
219 0
四所中国高校夺冠三大赛道,这场24个国家2500多支队伍角逐的算法竞赛刚刚落幕
|
机器学习/深度学习 人工智能 达摩院
为亿级用户的美好出行而战!高德地图首届算法大赛落幕 95后北邮在读博士带队夺冠
高德地图号召全球的开发者利用人工智能技术探索动态路况难题,收到了国内外顶尖学府、科研机构以及一线知名技术企业等产学研各界技术爱好者的积极响应。
为亿级用户的美好出行而战!高德地图首届算法大赛落幕 95后北邮在读博士带队夺冠