【编程之美挑战赛第一场】活动中心

时间限制:12000ms

单点时限:6000ms

内存限制:256MB

描写叙述

A市是一个高度规划的城市,可是科技高端发达的地方,居民们也不能忘记运动和锻炼,因此城市规划局在设计A市的时候也要考虑为居民们建造一个活动中心,方便居住在A市的居民们能随时开展运动,锻炼强健的身心。

城市规划局希望活动中心的位置满足下面条件:

1. 到全部居住地的总距离最小。

2. 为了方便活动中心的资源补给和其它器材的维护,活动中心必须建设在A市的主干道上。

为了简化问题,我们将A市摆在二维平面上,城市的主干道看作直角坐标系平的X轴,城市中全部的居住地都能够看成二维平面上的一个点。

如今,A市的城市规划局希望知道活动中心建在哪儿最好。

输入

第一行包含一个数T,表示数据的组数。

接下来包括T组数据,每组数据的第一行包括一个整数N,表示A市共同拥有N处居住地

接下来N行表示每处居住地的坐标。

输出

对于每组数据,输出一行“Case X: Y”,当中X表示每组数据的编号(从1開始),Y表示活动中心的最优建造位置。我们建议你的输出保留Y到小数点后6位或以上,不论什么与标准答案的绝对误差或者相对误差在10-6以内的结果都将被视为正确。

数据范围

小数据:1 ≤ T ≤ 1000, 1 ≤ N ≤ 10

大数据:1 ≤ T ≤ 10, 1 ≤ N ≤ 105

对于全部数据,坐标值都是整数且绝对值都不超过106

例子解释

例子1:活动中心的最优建造位置为(1.678787, 0)

例子输入
1
3
1 1
2 2
3 3
例子输出
Case 1: 1.678787

看了解题思路,三分查找,TT。。特点,求凹函数或者凸函数中的极值点,把公式带入距离,能够观察出总距离和事实上是一个凹函数?详细的数学推导给不出,我是个数学渣渣。。

直接看java 代码吧

import java.text.DecimalFormat;
import java.util.Arrays;
import java.util.Scanner;
import java.lang.String;
import java.lang.Math;
import java.util.HashSet;
/*
class TreeNode
{
	int val;
	TreeNode left;
	TreeNode right;
	TreeNode(int x) { val = x; left = null; right = null;}
}
class ListNode
{
	int val;
	ListNode next;
	ListNode(int x){val = x; next = null;}
}
*/
public class Solution {
	static long mode = 1000000007;
	/*
	public static void permutation(char[] str, HashSet<String> hashset, int start, int end) {
		if (start == end) {
			hashset.add(new String(str));
			//sum++;
		}
		else {
			for (int i = start; i <= end; i++) {
				char tmp = str[start];
				str[start] = str[i];
				str[i] = tmp;

				permutation(str, hashset, start+1, end);

				tmp = str[start];
				str[start] = str[i];
				str[i] = tmp;
			}
		}
	}
	*/

	public static void main(String[] args)
	{
		int T ;
		Scanner jin = new Scanner(System.in);
		T = jin.nextInt();
		for(int i = 0; i < T; i++)
		{
			int N = jin.nextInt();
			int[] x_array = new int[N];
			int[] y_array = new int[N];
			int minx = 1000000;
			int maxx = -100000;
			for (int j = 0; j < N; j++) {
				x_array[j] = jin.nextInt();
				y_array[j] = jin.nextInt();
				if (x_array[j] < minx) {
					minx = x_array[j];
				}
				if (x_array[j] > maxx) {
					maxx = x_array[j];
				}
			}
			double lo = minx;
			double hi = maxx;
			while ((hi-lo) >= 1e-7) {
				double mid = (lo+hi)/2;
				double mmid = (mid+hi)/2;
				double f1 = distance(mid, x_array, y_array);
				double f2 = distance(mmid, x_array, y_array);
				if (f1 < f2) {
					hi = mmid;
				}
				else lo = mid;
			}
			DecimalFormat df = new DecimalFormat("0.000000");
			System.out.println("Case " + i + ": " + df.format(lo));
		}

	}

	public static double distance(double x, int[] x_array, int[] y_array) {
		double dist = 0;
		for (int i = 0; i < x_array.length; i++) {
			dist += Math.sqrt((x-x_array[i])*(x-x_array[i]) + y_array[i]*y_array[i]);
		}
		return dist;
	}
}

【编程之美挑战赛第一场】活动中心

时间: 2024-08-24 01:36:24

【编程之美挑战赛第一场】活动中心的相关文章

【编程之美挑战赛第一场】树

时间限制:4000ms 单点时限:2000ms 内存限制:256MB 描写叙述 有一个N个节点的树.当中点1是根. 初始点权值都是0. 一个节点的深度定义为其父节点的深度+1,.特别的,根节点的深度定义为1. 如今须要支持一系列以下操作:给节点u的子树中,深度在l和r之间的节点的权值(这里的深度依旧从整个树的根节点開始计算),都加上一个数delta. 问完毕全部操作后,各节点的权值是多少. 为了降低巨大输出带来的开销,如果完毕全部操作后,各节点的权值是answer[1..N].请你依照例如以下方

微软2014编程之美初赛第一场——题目2 : 树

[来源] 题目2 : 树 [分析] 依据输入情况建立起树的模型.树的表示是一个表明父亲节点的数组.核心算法有两个: 计算某一节点的深度.用循环实现,一直向上找父亲节点,直到找到根节点.计算循环的次数即为深度. 计算某一节点的全部子节点.用递归实现. 本题在实现上节点的命名从0至N-1,与题目描写叙述不同. [代码] #include <iostream> #include <vector> using namespace std; vector<int> childre

微软2014编程之美初赛第一场——题目3 : 活动中心

[来源] 题目3 : 活动中心 [分析] 本题採用的是三分法. 输入的一组点中找出左右边界.作为起始边界. while(右边界-左边界<精度){ 将左右边界构成的线段均匀分成3段,推断切割点的距离关系,抹去距离大的一段.更新左右边界. } 输出左(右)边界 [代码] #include <iostream> #include <vector> #include <cmath> #include <iomanip> using namespace std;

2014微软编程之美初赛第一场第三题 活动中心

活动中心 时间限制:12000ms 单点时限:6000ms 内存限制:256MB 描写叙述 A市是一个高度规划的城市,可是科技高端发达的地方,居民们也不能忘记运动和锻炼,因此城市规划局在设计A市的时候也要考虑为居民们建造一个活动中心,方便居住在A市的居民们能随时开展运动,锻炼强健的身心. 城市规划局希望活动中心的位置满足下面条件: 1. 到全部居住地的总距离最小. 2. 为了方便活动中心的资源补给和其它器材的维护,活动中心必须建设在A市的主干道上. 为了简化问题.我们将A市摆在二维平面上,城市的

编程之美初赛第一场

题目3 : 活动中心 时间限制:12000ms 单点时限:6000ms 内存限制:256MB 描写叙述 A市是一个高度规划的城市.可是科技高端发达的地方,居民们也不能忘记运动和锻炼,因此城市规划局在设计A市的时候也要考虑为居民们建造一个活动中心.方便居住在A市的居民们能随时开展运动.锻炼强健的身心. 城市规划局希望活动中心的位置满足下面条件: 1. 到全部居住地的总距离最小. 2. 为了方便活动中心的资源补给和其它器材的维护,活动中心必须建设在A市的主干道上. 为了简化问题.我们将A市摆在二维平

编程之美初赛第一场--焦距

题目1 : 焦距 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描写叙述 一般来说.我们採用针孔相机模型,也就是觉得它用到的是小孔成像原理. 在相机坐标系下,一般来说,我们用到的单位长度.不是"米"这种国际单位,而是相邻像素的长度.而焦距在相机坐标系中的大小,是在图像处理领域的一个很重要的物理量. 如果我们已经依据相机參数,得到镜头的物理焦距大小(focal length),和相机胶片的宽度(CCD width),以及照片的横向分辨率(image width),

编程之美初赛第一场 树

题目2 : 树 时间限制:4000ms 单点时限:2000ms 内存限制:256MB 描写叙述 有一个N个节点的树.当中点1是根.初始点权值都是0. 一个节点的深度定义为其父节点的深度+1,.特别的.根节点的深度定义为1. 如今须要支持一系列下面操作:给节点u的子树中,深度在l和r之间的节点的权值(这里的深度依旧从整个树的根节点開始计算).都加上一个数delta. 问完毕全部操作后,各节点的权值是多少. 为了降低巨大输出带来的开销.如果完毕全部操作后.各节点的权值是answer[1..N],请你

2015编程之美初赛第一场 A 彩色的树

时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定一棵n个节点的树,节点编号为1, 2, -, n.树中有n - 1条边,任意两个节点间恰好有一条路径.这是一棵彩色的树,每个节点恰好可以染一种颜色.初始时,所有节点的颜色都为0.现在需要实现两种操作: 1. 改变节点x的颜色为y: 2. 询问整棵树被划分成了多少棵颜色相同的子树.即每棵子树内的节点颜色都相同,而相邻子树的颜色不同. 输入 第一行一个整数T,表示数据组数,以下是T组数据. 每组数据第一行是n,表示树的节

2015编程之美初赛第一场 B 建造金字塔

 时间限制:4000ms 单点时限:2000ms 内存限制:256MB 描述 在二次元中,金字塔是一个底边在x轴上的等腰直角三角形. 你是二次元世界的一个建筑承包商.现在有N个建造订单,每个订单有一个收益w,即建造此金字塔可获得w的收益.对每个订单可以选择建造或不建造. 建造一个金字塔的成本是金字塔的面积,如果两个或多个金字塔有重叠面积,则建造这些金字塔时重叠部份仅需建造一次. 建造一组金字塔的总利润是收益总和扣除成本.现给出这些订单,请求出最大利润. 输入 输入数据第一行为一个整数T,表示