[JSOI2008] [洛谷P1227] 完美的对称

题目描述 Description

在峰会期间,必须使用许多保镖保卫参加会议的各国代表。代表们除了由他自己的随身保镖保护外,组委会还指派了一些其他的特工和阻击手保护他们。为了使他们的工作卓有成效,使被保卫的人的安全尽可能得到保障,保镖被分配到被保护人的各个方向。
保镖的最佳站立位置应该是这样的:被保护人应站在所有保镖的对称中心。但是,只要被保
护人一移动,保镖就很难根据要人的新位置调整位置。大多数的特工都很难对此作出实时调整。

因此,安全部长决定将该过程逆转一下,保镖先站好自己的位置,然后要人在他们的对称中心找到合适的位置。如果要人随便走动,我们就对他的安全不必负责。

你的工作是使这个过程自动操作。给出一组N个点(保镖的位置),你要找出它们的对称中心S,在这儿被保护人将相对安全。下面以此类推。

首先我们给定一点A以及对称中心S,点A‘是点A以S为对称中心形成的像点,即点S是线段AA‘的对称中心。
点阵组(X)以S为中心的像点是由每个点的像点组成的点阵组。X是用来产生对称中心S的,即点阵X以S为中心的像点的集合即为点阵X本身。

输入输出格式 Input/output

输入格式:
输入文件第一行是一个整数N,1<=N<=20000,接下来的N行每行包含用空格隔开的两个整数Xi和Yi,-100000<=Xi,Yi<=100000,表示这组点阵中第I个点的笛卡尔坐标值。

因为任何两个保镖都不会站在同一个位置上,所以在给定的作业中,任何两点都不相同。但注意保镖可以站在被保护人相同的位置。
输出格式:
输出文件仅有一行。如果给定的点阵能产生一个对称中心,则输出“V.I.P.  should stay at (x,y).”,其中X和Y代表中心的笛卡尔坐标值,格式为四舍五入保留至小数点后一位。

如果该组点阵无对称中心,输出"This is a dangerous situation!",注意输出时除了两个单词之间用一个空格隔开外,不要输出多余空格。

输入输出样例 Sample input/output

样例测试点#1

输入样例:

8
1 10
3 6
6 8
6 2
3 -4
1 0
-2 -2
-2 4

输出样例:

V.I.P. should stay at (2.0,3.0).

分析:首先进行排序,横坐标为第一关键字,纵坐标为第二关键字,从小到大排序。以保证最左下的角在最前,最右上的角在最后。易证这两个点一定是一对中心对称的点。因此可以拟定一个中心对称点,即排序后第一个点与最后一个点的中点。然后将a[i]与a[n-i+1]耳的横纵坐标分别检验即可。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std;
int x[20001],y[20001],n;
double xx,yy;
int read()
{
    char c=getchar();
    int a=0;
    bool flag=false;
    while ((c<‘0‘||c>‘9‘)&&c!=‘-‘) c=getchar();
    if (c==‘-‘)
    {
                flag=true;
                c=getchar();
    }
    while (c>=‘0‘&&c<=‘9‘)
    {
          a=a*10+c-‘0‘;
          c=getchar();
    }
    if (flag) return -a;else return a;
}
void swap(int i,int j)
{
     int t;
     t=x[i]; x[i]=x[j]; x[j]=t;
     t=y[i]; y[i]=y[j]; y[j]=t;
}
void quicksort(int head,int tail)
{
     int i=head,j=tail,mid=(i+j)/2;
     while (i<j)
     {
           while (x[i]<x[mid]||x[i]==x[mid]&&y[i]<y[mid]) i++;
           while (x[j]>x[mid]||x[j]==x[mid]&&y[j]>y[mid]) j--;
           if (i<=j)
           {
                   swap(i,j);
                   i++;
                   j--;
           }
     }
     if (head<j) quicksort(head,j);
     if (i<tail) quicksort(i,tail);
}
int main()
{
    n=read();
    for (int i=1;i<=n;i++)
    {
        x[i]=read();
        y[i]=read();
    }
    quicksort(1,n);
    xx=((double)(x[1]+x[n])/2);
    yy=((double)(y[1]+y[n])/2);
    for (int i=2;i<=n/2+1;i++)
        if ((double)((x[i]+x[n-i+1])!=(xx*2))||(double)(y[i]+y[n-i+1])!=(yy*2))
        {
                                printf("This is a dangerous situation!");
                                exit(0);
        }
    printf("V.I.P. should stay at (%.1lf,%.1lf).\n",xx,yy);
    return 0;
}  
PS:题目描述多了空格,导致我WA好几遍,坑啊!
时间: 2024-12-23 06:00:25

[JSOI2008] [洛谷P1227] 完美的对称的相关文章

洛谷P1227[JSOI2008]完美的对称

洛谷P1227[JSOI2008]完美的对称 题目描述 在峰会期间,必须使用许多保镖保卫参加会议的各国代表.代表们除了由他自己的随身保镖保护外,组委会还指派了一些其他的特工和阻击手保护他们.为了使他们的工作卓有成效,使被保卫的人的安全尽可能得到保障,保镖被分配到被保护人的各个方向. 保镖的最佳站立位置应该是这样的:被保护人应站在所有保镖的对称中心.但是,只要被保 护人一移动,保镖就很难根据要人的新位置调整位置.大多数的特工都很难对此作出实时调整. 因此,安全部长决定将该过程逆转一下,保镖先站好自

[JSOI2008] [洛谷P1198] 最大数 [80&#39;]

题目描述 Description 现在请求你维护一个数列,要求提供以下两种操作:1. 查询操作.语法:Q L功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度.2. 插入操作.语法:A n功能:将n加上t,其中t是最近一次查询操作的答案(如果还未执行过查询操作,则t=0),并将所得结果对一个固定的常数D取模,将所得答案插入到数列的末尾.限制:n是整数(可能为负数)并且在长整范围内.注意:初始时数列是空的,没有一个数. 输入输出格式 Input/output

洛谷 P1227 [JSOI2008]完美的对称

题目描述 在峰会期间,必须使用许多保镖保卫参加会议的各国代表.代表们除了由他自己的随身保镖保护外,组委会还指派了一些其他的特工和阻击手保护他们.为了使他们的工作卓有成效,使被保卫的人的安全尽可能得到保障,保镖被分配到被保护人的各个方向. 保镖的最佳站立位置应该是这样的:被保护人应站在所有保镖的对称中心.但是,只要被保 护人一移动,保镖就很难根据要人的新位置调整位置.大多数的特工都很难对此作出实时调整. 因此,安全部长决定将该过程逆转一下,保镖先站好自己的位置,然后要人在他们的对称中心找到合适的位

洛谷P1198 [JSOI2008]最大数

P1198 [JSOI2008]最大数 267通过 1.2K提交 题目提供者该用户不存在 标签线段树各省省选 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 WA80的戳这QwQ BZOJ都过了,洛谷竟然过不了… 为什么过不了 = =我想说这题加优读会WA?… 谁说pascal只能80,要换c++… 线段树为什么是80? 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:L不超

[洛谷P1198/BZOJ1012][JSOI2008] 最大数 - 树状数组/线段树?

其实已经学了树状数组和线段树,然而懒得做题,所以至今没写多少博客 Description 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:L不超过当前数列的长度.(L>=0) 2. 插入操作. 语法:A n 功能:将n加上t,其中t是最近一次查询操作的答案(如果还未执行过查询操作,则t=0),并将所得结果对一个固定的常数D取模,将所得答案插入到数列的末尾. 限制:n是整数(可能为负数)并且在长整

洛谷P1519 穿越栅栏 Overfencing

P1519 穿越栅栏 Overfencing 69通过 275提交 题目提供者该用户不存在 标签USACO 难度普及/提高- 提交  讨论  题解 最新讨论 USACO是100分,洛谷是20分 为什么只有十分 题目描述 描述 农夫John在外面的田野上搭建了一个巨大的用栅栏围成的迷宫.幸运的是,他在迷宫的边界上留出了两段栅栏作为迷宫的出口.更幸运的是,他所建造的迷宫是一个“完美的”迷宫:即你能从迷宫中的任意一点找到一条走出迷宫的路.给定迷宫的宽度W(1<=W<=38)及高度H(1<=H&

洛谷OJ P1379 八数码难题 解题报告

洛谷OJ P1379 八数码难题 解题报告 by MedalPluS 题目描述   在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初始状态)和目标布局(为了使题目简单,设目标状态为123804765),找到一种最少步骤的移动方法,实现从初始布局到目标布局的转变.   输入格式   输入初试状态,一行九个数字,空格用0表示   输出格式 只有一行,该行只有一个数字,表示从初始状态到

图论 洛谷P2052 道路修建

P2052 道路修建 题目描述 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家 之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿 意修建恰好 n – 1 条双向道路. 每条道路的修建都要付出一定的费用,这个费用等于道路长度乘以道路两端 的国家个数之差的绝对值.例如,在下图中,虚线所示道路两端分别有 2 个.4 个国家,如果该道路长度为 1,则费用为 1×|2 – 4|=2.图中圆圈里的数字表示国 家的编号.  由于国家的数量十分庞大,道路的建造方案

【日常学习】【数学-其他】洛谷1403 约数研究题解

于是又要迎来洛谷那凌然无言以对的题目摘要= = 洛谷1403 约数研究 本题地址:http://www.luogu.org/problem/show?pid=1403 题目描述 科学家们在Samuel星球上的探险得到了丰富的能源储备,这使得空间站中大型计算机"Samuel2"的长时间运算成为了可能.由于在去年一年的辛苦工作取得了不错的成绩,小联允许用"Samuel2"进行数学研究. 小联最近在研究和约数有关的问题,他统计每个正数N的约数的个数,并以f(N)来表示.现