CodeForces 135B Rectangle and Square(暴力)

题意:要求你分成两个集合,一个是正方形,一个是矩形

思路:n只有8,所以直接暴力就好了


#include<bits\stdc++.h>
using namespace std;
const double eps = 1e-6;
double a[10],b[10];
vector<int>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<<tmp[i]+1<<" ";
            printf("\n");
            for(int i=4;i<8;i++)cout<<tmp[i]+1<<" ";
            return 0;
        }
    }while(next_permutation(tmp.begin(),tmp.end()));
    printf("NO\n");
}

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

Input
0 0
10 11
10 0
0 11
1 1
2 2
2 1
1 2
Output
YES
5 6 7 8
1 2 3 4
Input
0 0
1 1
2 2
3 3
4 4
5 5
6 6
7 7
Output
NO
Input
0 0
4 4
4 0
0 4
1 2
2 3
3 2
2 1
Output
YES
1 2 3 4
5 6 7 8

Hint

Pay attention to the third example: the figures do not necessarily have to be parallel to the coordinate axes.




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值