博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Codeforces Beta Round #97 (Div. 1) B. Rectangle and Square 暴力
阅读量:5366 次
发布时间:2019-06-15

本文共 3481 字,大约阅读时间需要 11 分钟。

B. Rectangle and Square

题目连接:

Description

Little Petya very much likes rectangles and especially squares. Recently he has received 8 points on the plane as a gift from his mother. The points are pairwise distinct. Petya decided to split them into two sets each containing 4 points so that the points from the first set lay at the vertexes of some square and the points from the second set lay at the vertexes of a rectangle. Each point of initial 8 should belong to exactly one set. It is acceptable for a rectangle from the second set was also a square. If there are several partitions, Petya will be satisfied by any of them. Help him find such partition. Note that the rectangle and the square from the partition should have non-zero areas. The sides of the figures do not have to be parallel to the coordinate axes, though it might be the case.

Input

You are given 8 pairs of integers, a pair per line — the coordinates of the points Petya has. The absolute value of all coordinates does not exceed 104. It is guaranteed that no two points coincide.

Output

Print in the first output line "YES" (without the quotes), if the desired partition exists. In the second line output 4 space-separated numbers — point indexes from the input, which lie at the vertexes of the square. The points are numbered starting from 1. The numbers can be printed in any order. In the third line print the indexes of points lying at the vertexes of a rectangle in the similar format. All printed numbers should be pairwise distinct.

If the required partition does not exist, the first line should contain the word "NO" (without the quotes), after which no output is needed.

Sample Input

xudyhduxyz

0 0
10 11
10 0
0 11
1 1
2 2
2 1
1 2

Sample Output

YES

5 6 7 8
1 2 3 4

题意

给你8个点,你需要分成2个set,使得左边那个set里面的点构成正方形,右边那个set里面的点构成长方形

问你可不可以,如果可以输出方案

题解:

只有8个点,直接暴力就好了……

判断直角,就直接点积就好了

代码

#include
using namespace std;const double eps = 1e-6;double a[10],b[10];vector
tmp,ans1,ans2;double dis(int x,int y){ return (a[x]-a[y])*(a[x]-a[y])+(b[x]-b[y])*(b[x]-b[y]);}double pointx(int x,int y,int z){ double x1=a[y]-a[x],y1=b[y]-b[x]; double x2=a[z]-a[x],y2=b[z]-b[x]; return x1*x2+y1*y2;}bool check(){ double len[4]; for(int i=0;i<4;i++)len[i]=dis(tmp[i],tmp[(i+1)%4]); for(int i=0;i<4;i++)for(int j=0;j<4;j++)if(fabs(len[i]-len[j])>eps)return false; if(fabs(pointx(tmp[0],tmp[1],tmp[3]))>eps)return false; if(fabs(pointx(tmp[1],tmp[0],tmp[2]))>eps)return false; if(fabs(pointx(tmp[2],tmp[1],tmp[3]))>eps)return false; if(fabs(pointx(tmp[3],tmp[2],tmp[0]))>eps)return false; for(int i=0;i<4;i++)len[i]=dis(tmp[i+4],tmp[(i+1)%4+4]); if(fabs(len[0]-len[2])>eps)return false; if(fabs(len[1]-len[3])>eps)return false; if(fabs(pointx(tmp[4],tmp[5],tmp[7]))>eps)return false; if(fabs(pointx(tmp[5],tmp[4],tmp[6]))>eps)return false; if(fabs(pointx(tmp[6],tmp[5],tmp[7]))>eps)return false; if(fabs(pointx(tmp[7],tmp[6],tmp[4]))>eps)return false; return true;}int main(){ for(int i=0;i<8;i++) { scanf("%lf%lf",&a[i],&b[i]); tmp.push_back(i); } do{ if(check()) { printf("YES\n"); for(int i=0;i<4;i++)cout<
<<" "; printf("\n"); for(int i=4;i<8;i++)cout<
<<" "; return 0; } }while(next_permutation(tmp.begin(),tmp.end())); printf("NO\n");}

转载于:https://www.cnblogs.com/qscqesze/p/5468737.html

你可能感兴趣的文章
在Flex中用Validator检测数字、字符串、Email.
查看>>
[leetcode]4Sum
查看>>
POJ1062 昂贵的聘礼
查看>>
【零基础学习iOS开发】【02-C语言】08-基本运算
查看>>
Java 将指定字符串连接到此字符串的结尾 concat()
查看>>
Hibernate Criterion
查看>>
Python知识
查看>>
我们为什么要搞长沙.NET技术社区(三)
查看>>
杭电acm Cake
查看>>
js函数中this的指向
查看>>
c++ 引用方式传递数组
查看>>
HBase学习之路 (九)HBase phoenix的使用
查看>>
LeetCode() Remove Duplicates from Sorted Array II
查看>>
【svn】idea svn 文件上会出现一个破书
查看>>
cocos2d-x 3.0 场景切换特效汇总(转)
查看>>
The SortedMap Interface
查看>>
SniperOJ-leak-x86-64
查看>>
bzoj 4260: Codechef REBXOR (01 Trie)
查看>>
学好python
查看>>
css-IE中的border-radius和box-shadow
查看>>