码迷,mamicode.com
首页 > 其他好文 > 详细

Codeforces Round #265 (Div. 2) D. Restore Cube

时间:2014-09-18 16:36:44      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:des   style   io   os   ar   for   div   art   sp   

Peter had a cube with non-zero length of a side. He put the cube into three-dimensional space in such a way that its vertices lay at integer points (it is possible that the cube‘s sides are not parallel to the coordinate axes). Then he took a piece of paper and wrote down eight lines, each containing three integers — coordinates of cube‘s vertex (a single line contains coordinates of a single vertex, each vertex is written exactly once), put the paper on the table and left. While Peter was away, his little brother Nick decided to play with the numbers on the paper. In one operation Nick could swap some numbers inside a single line (Nick didn‘t swap numbers from distinct lines). Nick could have performed any number of such operations.

When Peter returned and found out about Nick‘s mischief, he started recollecting the original coordinates. Help Peter restore the original position of the points or else state that this is impossible and the numbers were initially recorded incorrectly.

Input

Each of the eight lines contains three space-separated integers — the numbers written on the piece of paper after Nick‘s mischief. All numbers do not exceed 106 in their absolute value.

Output

If there is a way to restore the cube, then print in the first line "YES". In each of the next eight lines print three integers — the restored coordinates of the points. The numbers in the i-th output line must be a permutation of the numbers in i-th input line. The numbers should represent the vertices of a cube with non-zero length of a side. If there are multiple possible ways, print any of them.

If there is no valid way, print "NO" (without the quotes) in the first line. Do not print anything else.

Sample test(s)
Input
0 0 0
0 0 1
0 0 1
0 0 1
0 1 1
0 1 1
0 1 1
1 1 1
Output
YES
0 0 0
0 0 1
0 1 0
1 0 0
0 1 1
1 0 1
1 1 0
1 1 1
Input
0 0 0
0 0 0
0 0 0
0 0 0
1 1 1
1 1 1
1 1 1
1 1 1
Output
NO
题意:给你8个点,让你任意重排点的坐标,问是否能组成正方体
思路:排列8个点坐标,判断立方体:看看最短的边和面的斜边以及对顶点的关系
#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <cmath>
typedef long long ll;
using namespace std;

ll a[10][10], b[10];

ll dis(int i, int j) {
	ll x = a[i][0] - a[j][0];
	ll y = a[i][1] - a[j][1];
	ll z = a[i][2] - a[j][2];
	return x * x + y * y + z * z;
}

int check() {
	for (int i = 0; i < 8; i++) {
		for (int j = 0; j < 8; j++) {
			if (i == j)
				continue;
			if (j < i)
				b[j] = dis(i, j);
			else b[j-1] = dis(i, j);
		}
		sort(b, b+7);
		ll t1 = b[0], t2 = 2 * b[0], t3 = 3 * b[0];
		if (t1 == 0 || t1 != b[1] || t1 != b[2] || t2 != b[3] || t2 != b[4] || t2 != b[5] || t3 != b[6])
			return 0;
	}
	return 1;
}

int isOk(int cur) {
	if (cur == 8) 
		return check();

	sort(a[cur], a[cur]+3);
	do {
		if (isOk(cur+1))
			return 1;
	} while (next_permutation(a[cur], a[cur]+3));
	return 0;
}

int main() {
	for (int i = 0; i < 8; i++)
		cin >> a[i][0] >> a[i][1] >> a[i][2];

	if (!isOk(0))
		printf("NO\n");
	else {
		printf("YES\n");
		for (int i = 0; i < 8; i++)	{
			for (int j = 0; j < 3; j++)
				cout << a[i][j] << " ";
			printf("\n");
		}
	}
	return 0;
}


Codeforces Round #265 (Div. 2) D. Restore Cube

标签:des   style   io   os   ar   for   div   art   sp   

原文地址:http://blog.csdn.net/u011345136/article/details/39372371

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!