题意:平面上给若干点,问它们是不是关于某垂直于x轴的直线对称。


代码:(Wrong Answer, –ms)

//UVa1595 - Symmetry
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
struct point {
int x, y;
bool operator <(point& that)const {
if (y == that.y) return x < that.x;
return y < that.y;
}
};
int T, N; int main() {
//freopen("in.txt", "r", stdin);
scanf("%d", &T);
while (T--) {
scanf("%d", &N);
vector<point> all(N);
int sym(0);//2倍的对称轴
for (auto &r : all) {
scanf("%d%d", &r.x, &r.y);
sym += r.x;
}
sym = sym * 2 / N;
sort(all.rbegin(), all.rend());
//printf("sym:%d\n", sym);for (int i = 0;i < N;++i) printf("%d&%d ", all[i].y, all[i].x);printf("\n");//------------
int i = 0;
while (i < N) {
int k, ij, j = i;
while (++j != N && all[j].y == all[i].y);
ij = (--j - i) / 2;
//printf("i:%d\t", i);printf("j:%d\t", j);printf("ij:%d\n", ij);//----------
for (k = 0;k <= ij;++k) {
if (all[i + k].x + all[j - k].x != sym) break;
}
if (k <= ij) break;
i = j + 1;
}
printf((i < N ? "NO\n" : "YES\n"));
}
return 0;
}

分析:好气呀,这么简单的题目,做了一下午+一上午,无限WA,至今找不到错误。不玩了,学会放弃,以后有心情再看。

我的想法是:定义一个结构体存每个点的x、y,读取每个数据后排序,优先y从小到大,其次x从小到大(目的是方便找出每个点对应的点。例如相同的y里面,最小的x与最大的x对应)。随便找出一个可能的对称轴(可以是找最大、最小的x,相加除以二;也可以所有的x相加再除以N。我选的后者)。然后取每对对应的两个点看相加的结果是不是对称轴两倍。

然而自己的测试数据都对,到了提交就总是WA。换成网上都用的set的方法重新做一遍,还是WA,开始怀疑人生。以下是我的测试数据,我实在是找不到其他的特殊情况了。

12

5
-2 5
0 0
6 5
4 0
2 3 4
2 3
0 4
4 0
0 0 4
5 14
6 10
5 10
6 14 10
7 -666
0 5
-1 -666
7 5
3 4
0 -666
4 4
4 -666
3 -666
8 -666 1
233 322 2
-10000 999
9999 998 2
-999 999
0 999 3
1 1
2 1
4 1 3
1 1
2 1
3 1 3
1 1
2 2
3 1 4
0 1
2 1
3 1
5 1 37
1 1
2 2
3 3
4 4
5 5
6 6
7 7
8 8
9 9
1 9
2 8
3 7
4 6
6 4
7 3
8 2
9 1
5 6
5 7
5 55
5 4
5 3
5 -45
6 5
7 5
8 5
10 5
55 5
4 5
3 5
2 5
0 5
-45 5
8 100
7 100
3 100
2 100

[刷题]算法竞赛入门经典(第2版) 5-6/UVa1595 - Symmetry的更多相关文章

  1. [刷题]算法竞赛入门经典(第2版) 4-6/UVa508 - Morse Mismatches

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,10 ms) //UVa508 - Morse Mismatches #include< ...

  2. [刷题]算法竞赛入门经典(第2版) 5-15/UVa12333 - Revenge of Fibonacci

    题意:在前100000个Fibonacci(以下简称F)数字里,能否在这100000个F里找出以某些数字作为开头的F.要求找出下标最小的.没找到输出-1. 代码:(Accepted,0.250s) / ...

  3. [刷题]算法竞赛入门经典(第2版) 5-13/UVa822 - Queue and A

    题意:模拟客服MM,一共有N种话题,每个客服MM支持处理其中的i个(i < N),处理的话题还有优先级.为了简化流程方便出题,设每个话题都是每隔m分钟来咨询一次.现知道每个话题前来咨询的时间.间 ...

  4. [刷题]算法竞赛入门经典(第2版) 4-5/UVa1590 - IP Networks

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa1590 - IP Networks #include<iost ...

  5. [刷题]算法竞赛入门经典(第2版) 6-7/UVa804 - Petri Net Simulation

    题意:模拟Petri网的执行.虽然没听说过Petri网,但是题目描述的很清晰. 代码:(Accepted,0.210s) //UVa804 - Petri Net Simulation //Accep ...

  6. [刷题]算法竞赛入门经典(第2版) 6-6/UVa12166 - Equilibrium Mobile

    题意:二叉树代表使得平衡天平,修改最少值使之平衡. 代码:(Accepted,0.030s) //UVa12166 - Equilibrium Mobile //Accepted 0.030s //# ...

  7. [刷题]算法竞赛入门经典(第2版) 6-1/UVa673 6-2/UVa712 6-3/UVa536

    这三题比较简单,只放代码了. 题目:6-1 UVa673 - Parentheses Balance //UVa673 - Parentheses Balance //Accepted 0.000s ...

  8. [刷题]算法竞赛入门经典(第2版) 5-16/UVa212 - Use of Hospital Facilities

    题意:模拟患者做手术. 其条件为:医院有Nop个手术室.准备手术室要Mop分钟,另有Nre个恢复用的床.准备每张床要Mre分钟,早上Ts点整医院开张,从手术室手术完毕转移到回复床要Mtr分钟.现在医院 ...

  9. [刷题]算法竞赛入门经典(第2版) 5-11/UVa12504 - Updating a Dictionary

    题意:对比新老字典的区别:内容多了.少了还是修改了. 代码:(Accepted,0.000s) //UVa12504 - Updating a Dictionary //#define _XieNao ...

  10. [刷题]算法竞赛入门经典(第2版) 5-10/UVa1597 - Searching the Web

    题意:不难理解,照搬题意的解法. 代码:(Accepted,0.190s) //UVa1597 - Searching the Web //#define _XIENAOBAN_ #include&l ...

随机推荐

  1. flask-mail发送QQ邮件代码示例(亲测可行)

    from flask import Flask from flask_mail import Mail, Message app = Flask(__name__) app.config.update ...

  2. python运用中文注释时报错解决方法

    写了一段简单的代码,不知 为什么总是报错,后来上网查了一下才知道原因,当用中文进行注释时需要添加如下代码:# coding=utf-8          (注意:该段代码必须放在最前面才能有用,并且 ...

  3. ubuntu-terminal快捷键

    常用快捷键功能:Tab 自动补全 Ctrl+a 光标移动到开始位置 Ctrl+e 光标移动到最末尾 Ctrl+k 删除此处至末尾的所有内容 Ctrl+u 删除此处至开始的所有内容 Ctrl+d 删除当 ...

  4. 老李推荐:第6章6节《MonkeyRunner源码剖析》Monkey原理分析-事件源-事件源概览-命令队列

    老李推荐:第6章6节<MonkeyRunner源码剖析>Monkey原理分析-事件源-事件源概览-命令队列   事件源在获得字串命令并把它翻译成对应的MonkeyEvent事件后,会把这些 ...

  5. React Native 导入原生Xcode项目总结与记录

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  6. Android中java层使用LocalSocket和底层进行通讯

    原始文件:frameworks\base\services\java\com\android\server\NativeDaemonConnector.java private void listen ...

  7. windows server 定期备份数据库脚本

    将以下文件保存为.bat脚本,在计划任务中添加定时任务运行此脚本即可.脚本中的备份目录,数据库目录和压缩文件目录请自行修改. @echo off rem 当前路径切换到备份数据库目录 cd D:\wa ...

  8. MYSQL数据库导入大数据量sql文件失败的解决方案

    1.在讨论这个问题之前首先介绍一下什么是"大数据量sql文件". 导出sql文件.选择数据库-----右击选择"转储SQL文件"-----选择"结构和 ...

  9. selenium实例:unittest框架+PO开发模式

    这是<selenium2+python学习总结>的升级版. 1.         项目结构 2.         项目代码 1)         globalparameter.py # ...

  10. 重新认识JavaScript里的创建对象(一)

    一.序 面向对象有一个标志,那就是它们都有类的概念,而通过类可以创建任意多个具有相同属性和方法的对象.ECMA-262把对象定义为"无序属性的集合,其属性可以包含基本值.对象或者函数&quo ...