题目大意: 给定一些正方体的关系,要求一组符合这些关系的正方体坐标,如果不存在符合条件的正方体坐标,IMPOSSIBLE。(Special Judge)

实力还是太弱了,完全不会……

#include <cstdio>
#include <stdlib>
#include <iostream>
#define MAXN 2010
#define MAXR 500000
#define MAX 999999 typedef struct edges{
int v,w,next;
}edge; int N, R;
edge edge_X[MAXR], edge_Y[MAXR], edge_Z[MAXR];
int s_X[MAXN], s_Y[MAXN], s_Z[MAXN];
int index_X[MAXN], index_Y[MAXN], index_Z[MAXN];
int degree_X[MAXN], degree_Y[MAXN], degree_Z[MAXN]; void Add(struct edges e[], int start, int end, int index[], int degree[], int &tot){
e[tot].v = end;
e[tot].next = index[start];
index[start] = tot++;
degree[end]++;
} bool init(){
int i, totx, toty, totz;
scanf("%d%d", &N, &R);
if (N == 0 && R == 0) return false;
memset(index_X, 255, sizeof(*index_X)*MAXN); //-1 indicates end of link
memset(index_Y, 255, sizeof(*index_Y)*MAXN);
memset(index_Z, 255, sizeof(*index_Z)*MAXN);
memset(degree_X, 0, sizeof(*degree_X)*MAXN);
memset(degree_Y, 0, sizeof(*degree_Y)*MAXN);
memset(degree_Z, 0, sizeof(*degree_Z)*MAXN);
totx = toty = totz = 0; for (i=1; i<=N; i++){
// node 0是超级汇点,最大的点。值为0
Add(edge_X, 0, i, index_X, degree_X, totx); //x1 of n-th Cube
Add(edge_Y, 0, i, index_Y, degree_Y, toty);
Add(edge_Z, 0, i, index_Z, degree_Z, totz);
Add(edge_X, i, i+N, index_X, degree_X, totx);
Add(edge_Y, i, i+N, index_Y, degree_Y, toty);
Add(edge_Z, i, i+N, index_Z, degree_Z, totz);
}
for (i=1; i<=R; i++){
char t[10];
int A, B;
scanf("%s%d%d", t, &A, &B);
if (t[0] == 'I'){
Add(edge_X, A, B+N, index_X, degree_X, totx); //x1(A) < x1(B)
Add(edge_X, B, A+N, index_X, degree_X, totx); //x2(A) > x1(B) or x1(B) < x2(A)
Add(edge_Y, A, B+N, index_Y, degree_Y, toty);
Add(edge_Y, B, A+N, index_Y, degree_Y, toty);
Add(edge_Z, A, B+N, index_Z, degree_Z, totz);
Add(edge_Z, B, A+N, index_Z, degree_Z, totz);
}
if (t[0] == 'X')
Add(edge_X, A+N, B, index_X, degree_X, totx); //x2(A) < x1(B)
if (t[0] == 'Y')
Add(edge_Y, A+N, B, index_Y, degree_Y, toty); //y2(A) < y1(B)
if (t[0] == 'Z')
Add(edge_Z, A+N, B, index_Z, degree_Z, totz); //z2(A) < z1(B)
}
return true;
} bool NonPreFirstTopSort(edge e[], int index[], int degree[], int n, int s[]){
int i, count(0), head(0), tail(1);
int Q[MAXN]; Q[0] = 0; while (head != tail){
s[Q[head]] = count++;
i = index[Q[head]];
while (i != -1){
if (--degree[e[i].v] == 0) Q[tail++] = e[i].v;
i = e[i].next;
}
++head;
} if (count < n) return false;
else return true;
} int main(){
int Cases = 0, i;
while (init() && ++Cases){
bool flag;
flag = NonPreFirstTopSort(edge_X, index_X, degree_X, N*2 + 1, s_X);
if (flag) flag = NonPreFirstTopSort(edge_Y, index_Y, degree_Y, N*2 + 1, s_Y);
if (flag) flag = NonPreFirstTopSort(edge_Z, index_Z, degree_Z, N*2 + 1, s_Z);
if (flag){
printf("Case %d: POSSIBLE\n", Cases);
for (i=1; i<=N; i++)
printf("%d %d %d %d %d %d\n", s_X[i], s_Y[i], s_Z[i], s_X[i+N], s_Y[i+N], s_Z[i+N]);
printf("\n"); }
else
printf("Case %d: IMPOSSIBLE\n\n", Cases);
}
//system("pause");
return 0;
}

HDU 3231 Box Relations的更多相关文章

  1. hdu 3231 Box Relations (拓扑排序)

    Box Relations Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  2. HDU 3213 Box Relations(拓扑排序构造)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3231 题意:有n个长方体,四种限制条件.(1)I x y x和y有相交:(2)X/Y/Z  x y x ...

  3. HDU3231 Box Relations——三维拓扑排序

    HDU3231 Box Relations 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3231 题目意思:在一个三维空间上有一些棱和坐标轴平行的立方 ...

  4. HDU 2475 BOX 动态树 Link-Cut Tree

    Box Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) [Problem De ...

  5. HDU 2088 Box of Bricks

    http://acm.hdu.edu.cn/showproblem.php?pid=2088 Problem Description Little Bob likes playing with his ...

  6. HDU 2088 Box of Bricks(脑洞)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2088 Box of Bricks Time Limit: 1000/1000 MS (Java/Oth ...

  7. HDU 2475 Box

    Box Time Limit: 5000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ID: 247564 ...

  8. 『嗨威说』算法设计与分析 - 贪心算法思想小结(HDU 2088 Box of Bricks)

    本文索引目录: 一.贪心算法的基本思想以及个人理解 二.汽车加油问题的贪心选择性质 三.一道贪心算法题点拨升华贪心思想 四.结对编程情况 一.贪心算法的基本思想以及个人理解: 1.1 基本概念: 首先 ...

  9. HDU 1326 Box of Bricks(水~平均高度求最少移动砖)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1326 题目大意: 给n堵墙,每个墙的高度不同,求最少移动多少块转使得墙的的高度相同. 解题思路: 找到 ...

随机推荐

  1. 使用 UML 进行业务建模:理解业务用例与系统用例的相似和不同之处

    使用 UML 进行业务建模:理解业务用例与系统用例的相似和不同之处   作者:Arthur V. English 出处:IBM   本文内容包括: 背景 业务用例模型与系统用例模型有什么相似之处? 业 ...

  2. C++ Member Functions的各种调用方式

    [1]Nonstatic Member Functions(非静态成员函数) C++的设计准则之一就是:nonstatic member function至少必须和一般的nonmember funct ...

  3. Java学习之字符串的创建

    转自:http://lavasoft.blog.51cto.com/62575/80034/ Java字符串类(java.lang.String)是Java中使用最多的类,也是最为特殊的一个类,很多时 ...

  4. Struts2知识总结

    整篇参考:http://blog.csdn.net/zq9017197/article/details/5958627 要搞清楚以下几点: 1.Struts2是什么?它的运行原理是什么? 2.Stru ...

  5. 怎样使用Markdown

    转自:http://wowubuntu.com/markdown/basic.html 段落.标题.区块代码 一个段落是由一个以上的连接的行句组成,而一个以上的空行则会划分出不同的段落(空行的定义是显 ...

  6. 对discuz的代码分析学习(二)首页文件

    如果当前地址栏存在查询字符,并且是一个数字,条件成立. 查询字符:www.baidu.com/index.php?aaa=bbb              aaa=bbb就是查询字符如果条件成立,则把 ...

  7. codeforces 632F. Magic Matrix

    题目链接 给一个n*n的矩阵, 问是否对角线上的元素全都为0, a[i][j]是否等于a[j][i], a[i][j]是否小于等于max(a[i][k], a[j][k]), k为任意值. 前两个都好 ...

  8. java axis web service

    编写 java调用web service的客户端比较简单,其中webservice为上一篇gsoap创建的server. package clientTest; import java.rmi.Rem ...

  9. java selenium webdriver实战 seleniumIDE

    Selenium是ThoughtWorks公司,一个名为Jason Huggins的测试为了减少手工测试的工作量,自己实现的一套基于Javascript语言的代码库 使用这套库可以进行页面的交互操作, ...

  10. 多线程中Local Store Slot(本地存储槽)

    在Java中有一种ThreadLocal机制,为每一个使用该变量的线程都提供一个变量值的副本,是每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突.从线程的角度看,就好像每一个线程都完全 ...