有一个 n * n * n 的立方体,其中一些单位立方体已经缺失(剩下部分不一定连通)。每个单位立方体重 1 克,且被涂上单一的颜色(即 6 个面的一颜色相同)。给出前、左、后、右、顶、底 6 个视图,你的任务是判断这个屋里剩下的最大的重量。

看完这题之后,我满头雾水,不知道从何下手。后来模拟了一下数据,才知道怎么解决。

首先,一个单位立方体只有一种颜色,如果从不同的视图看到这个立方体的颜色不同,那么就删除这个立方体。通过这样循环删除,到最后所有的小立方体都符合题目所要求,就是最大的立方体数目,即最大的重量。

附AC代码:

   1: #include <stdio.h>

   2: #include <math.h>

   3: #include <iostream>

   4: #include <cstdarg>

   5: #include <algorithm>

   6: #include <string.h>

   7: #include <stdlib.h>

   8: #include <string>

   9: #include <list>

  10: #include <vector>

  11: #include <map>

  12: #define LL long long

  13: #define M(a) memset(a, 0, sizeof(a))

  14: #define orz(i, k) for(int i = 0; i < k; i++)

  15: using namespace std;

  16:     int n;

  17: void Clean(int count, ...)

  18: {

  19:     va_list arg_ptr;

  20:     va_start (arg_ptr, count);

  21:     for (int i = 0; i < count; i++)

  22:         M(va_arg(arg_ptr, int*));

  23:     va_end(arg_ptr);

  24: }

  25: char Input()

  26: {

  27:     char ch;

  28:     while (1)

  29:     {

  30:         ch = getchar();

  31:         if (ch >= 'A' && ch <= 'Z') return ch;

  32:         else if (ch == '.') return ch;

  33:     }

  34: }

  35:  

  36: void Get(int k, int i, int j, int len, int &x, int &y, int &z)

  37: {

  38:     switch (k)

  39:     {

  40:         case 0: x = len, y = j, z = i; break;

  41:         case 1: x = n - 1 - j, y = len, z = i; break;

  42:         case 2: x = n - 1 - len, y = n - 1 - j, z = i; break;

  43:         case 3: x = j, y = n - 1 - len, z = i; break;

  44:         case 4: x = n - 1 - i, y = j, z = len; break;

  45:         case 5: x = i, y = j, z = n - 1 - len; break;

  46:     }

  47: }

  48:  

  49: char pos[10][10][10];

  50: char view[6][10][10];

  51: int main()

  52: {

  53:     while (~scanf("%d", &n) && n)

  54:     {

  55:         Clean(1, view);

  56:  

  57:         orz(i, n) orz(j, 6) orz(k, n) view[j][i][k] = Input();

  58:         orz(i, n) orz(j, n) orz(k, n) pos[i][j][k] = '#';

  59:         orz(k, 6) orz(i, n) orz(j, n)

  60:         {

  61:             if (view[k][i][j] == '.')

  62:             {

  63:                 orz(l, n)

  64:                 {

  65:                     int x, y, z;

  66:                     Get(k, i, j, l, x, y, z);

  67:                     pos[x][y][z] = '.';

  68:                 }

  69:             }

  70:         }

  71:         while (1)

  72:         {

  73:             bool done = true;

  74:             orz(k, 6) orz(i, n) orz(j, n)

  75:             {

  76:                 orz(l, n)

  77:                 {

  78:                     int x, y, z;

  79:                     Get(k, i, j, l, x, y, z);

  80:                     if (pos[x][y][z] == '.') continue;

  81:                     else if (pos[x][y][z] == '#')

  82:                     {

  83:                         pos[x][y][z] = view[k][i][j];

  84:                         break;

  85:                     }

  86:                     if (pos[x][y][z] == view[k][i][j]) break;

  87:                     pos[x][y][z] = '.';

  88:                     done = false;

  89:                 }

  90:             }

  91:             if (done == true) break;

  92:         }

  93:         int res = 0;

  94:         orz(i, n) orz(j, n) orz(k, n)

  95:             if (pos[i][j][k] != '.') res += 1;

  96:         printf("Maximum weight: %d gram(s)\n", res);

  97:     }

  98:     return 0;

  99: }

(P. S:弄出来之后感觉好有成就感Orz)

LA 2995 Image Is Everything 立方体成像 World Final 2004的更多相关文章

  1. LA 2995 立方体成像(模拟)

    题目链接:https://vjudge.net/problem/UVALive-2995 这道题的主要难点在于三维坐标系的建立,然后在坐标系中进行迭代更新. 注意用宏定义来简化代码. AC代码: #i ...

  2. [ACM_模拟][ACM_数学] LA 2995 Image Is Everything [由6个视图计算立方体最大体积]

    Description   Your new company is building a robot that can hold small lightweight objects. The robo ...

  3. LA 2995 Image Is Everything

    题目链接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show ...

  4. poj2196

    Specialized Four-Digit Numbers Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7238   A ...

  5. ZOJ2405 Specialized Four-Digit Numbers 2017-04-18 20:43 44人阅读 评论(0) 收藏

    Specialized Four-Digit Numbers Time Limit: 2 Seconds      Memory Limit: 65536 KB Find and list all f ...

  6. OpenGL立方体在世界坐标系中_缩放_旋转_平移_顶点片源着色器_光照作用_棋盘纹理贴图

    读取bmp等图片格式中的像素还有难度,就先用这个棋盘图象素来弄了 代码打错一个就一直First-chance exception ,貌似还有一个要用q或者Q才能成功退出,不知道缺少哪句,我用窗口红叉退 ...

  7. 数据立方体(Cube)

    如上图所示,这是由三个维度构成的一个OLAP立方体,立方体中包含了满足条件的cell(子立方块)值,这些cell里面包含了要分析的数据,称之为度量值.显而易见,一组三维坐标唯一确定了一个子立方. 多位 ...

  8. 数据立方体----维度与OLAP

    前面的一篇文章——数据仓库的多维数据模型中已经简单介绍过多维模型的定义和结构,以及事实表(Fact Table)和维表(Dimension Table)的概念.多维数据模型作为一种新的逻辑模型赋予了数 ...

  9. CSS3 3D立方体效果-transform也不过如此

    CSS3系列已经学习了一段时间了,第一篇文章写了一些css3的奇技淫巧,原文戳这里,还获得了较多网友的支持,在此谢过各位,你们的支持是我写文章最大的动力^_^. 那么这一篇文章呢,主要是通过一个3D立 ...

随机推荐

  1. CyclicBarrier、CountDownLatch与Semaphore的小记

    CyclicBarrier: 适合的业务场景,比如 1).,现有一大任务,需要得到全年的统计数据的,这个工作量是巨大的,那么可以将其分割为12个月的子任务,各个子任务相互独立,当所有子任务完成了,则就 ...

  2. Spine的纹理导出问题

    发现美术给过来的资源,集合到unity后,发现用Spine的默认材质Spine/Skeleton有毛边问题.对比demo的图片后发现demo的图片(都是png格式)没有白色块,而自己的图片有. 原因是 ...

  3. hdu 4472 Count

    递推,一般的dp值: #include<stdio.h> #include<string.h> #define mod 1000000007 ]; int Dp() { a[] ...

  4. mysql主从配置(转载)

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://369369.blog.51cto.com/319630/790921 还可以参考 ...

  5. JAVA编译异常处理:java.lang.OutOfMemoryError: PermGen space

    在Intellij开发工具中编译JAVA项目,出现以下错误: 六月 21, 2016 6:28:07 下午 org.apache.tomcat.util.modeler.BaseModelMBean ...

  6. JSP下载txt 和 Excel两种文件

    JSP下载txt 和 Excel两种文件 jsp 下载txt文件和excel文件   jsp 下载txt文件和excel文件 最近做了个用jsp下载的页面 将代码贴出来 权作记录吧 1 下载txt文件 ...

  7. linux环境下,利用tc限制两台服务器间的网速,非常简单。

    最近再搞postgres的数据同步,需要模拟异地机房有带宽限制时的同步效果,所以想要限制一下两台机器之间的网速. ts命令功能很强,同时也好难理解和使用,经常浪费了好半天还是搞不定. 这里分享一个简单 ...

  8. DeepLearning常用库简要介绍与对比

    网上近日流传一张DL相关库在Github上的受关注度对比(数据应该是2016/03/15左右统计的): 其中tensorflow,caffe,keras和Theano排名比较靠前. 今日组会报告上tj ...

  9. Bootstrap plugin编写

    滚动demo: <!doctype html> <html lang="en"> <head> <meta charset="U ...

  10. Linux内核的整体架构

    Linux内核的整体架构 作者:蜗蜗 发布于:2014-2-21 13:23 分类:Linux内核分析 原文:http://www.wowotech.net/linux_kenrel/11.html ...