LA 2995 Image Is Everything 立方体成像 World Final 2004
有一个 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的更多相关文章
- LA 2995 立方体成像(模拟)
题目链接:https://vjudge.net/problem/UVALive-2995 这道题的主要难点在于三维坐标系的建立,然后在坐标系中进行迭代更新. 注意用宏定义来简化代码. AC代码: #i ...
- [ACM_模拟][ACM_数学] LA 2995 Image Is Everything [由6个视图计算立方体最大体积]
Description Your new company is building a robot that can hold small lightweight objects. The robo ...
- LA 2995 Image Is Everything
题目链接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show ...
- poj2196
Specialized Four-Digit Numbers Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7238 A ...
- 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 ...
- OpenGL立方体在世界坐标系中_缩放_旋转_平移_顶点片源着色器_光照作用_棋盘纹理贴图
读取bmp等图片格式中的像素还有难度,就先用这个棋盘图象素来弄了 代码打错一个就一直First-chance exception ,貌似还有一个要用q或者Q才能成功退出,不知道缺少哪句,我用窗口红叉退 ...
- 数据立方体(Cube)
如上图所示,这是由三个维度构成的一个OLAP立方体,立方体中包含了满足条件的cell(子立方块)值,这些cell里面包含了要分析的数据,称之为度量值.显而易见,一组三维坐标唯一确定了一个子立方. 多位 ...
- 数据立方体----维度与OLAP
前面的一篇文章——数据仓库的多维数据模型中已经简单介绍过多维模型的定义和结构,以及事实表(Fact Table)和维表(Dimension Table)的概念.多维数据模型作为一种新的逻辑模型赋予了数 ...
- CSS3 3D立方体效果-transform也不过如此
CSS3系列已经学习了一段时间了,第一篇文章写了一些css3的奇技淫巧,原文戳这里,还获得了较多网友的支持,在此谢过各位,你们的支持是我写文章最大的动力^_^. 那么这一篇文章呢,主要是通过一个3D立 ...
随机推荐
- js中的call与apply
看js权威指南里面关于call与apply方法的说明:我们可以将call()与apply()看作是某个对象的方法,通过调用方法的形式来间接调用函数.这样的解释未免使人糊涂啊.下面说一下自己的见解:其实 ...
- linux 中permission denied的问题:
执行安装命令的时候 ./install 遇到 permission denied, bash: ./install: Permission denied另外,在 root下也是同样的问题, 请教该如何 ...
- Jackson学习笔记-对象序列化
一.用ObjectMapper.readValue(jsonString, Student.class) , ObjectMapper.writeValueAsString(student) impo ...
- Delphi动态事件深入分析(对象方法在调用的时候会传递一个隐含的Self指针,而该指针的值在EAX中。即左边第一个参数)
Delphi动态事件深入分析 2009-2-7 作者:不得闲核心提示:本实验证明了在类中方法的调用时候,所有的方法都隐含了一个Self参数,并且该参数作为对象方法的第一个参数传递... 首先做一个空窗 ...
- Python实现ssh批量登录并执行命令
局域网内有一百多台电脑,全部都是linux操作系统,所有电脑配置相同,系统完全相同(包括用户名和密码),ip地址是自动分配的.现在有个任务是在这些电脑上执行某些命令,者说进行某些操作,比如安装某些软件 ...
- PHP高级特性二之文件处理
PHP中的文件处理也是一个相当重要的模块,这一篇的主要内容就是PHP中文件系统的简介. 文件系统用途 1. 项目处理都离不开文件处理 2. 可以用文件长时间保存数据 3. 建立缓存,在服务器中进行文件 ...
- A Bug
A Bug Time Limit: 1000MS Memory Limit: 65535KB Submissions: 231 Accepted: Descr ...
- Linux内核同步机制之(三):memory barrier【转】
转自:http://www.wowotech.net/kernel_synchronization/memory-barrier.html 一.前言 我记得以前上学的时候大家经常说的一个词汇叫做所见即 ...
- LINUX内核分析第四周学习总结——扒开应用系统的三层皮(上)【转】
转自:http://www.cnblogs.com/lalacindy/p/5276874.html 张忻(原创作品转载请注明出处) <Linux内核分析>MOOC课程http://moo ...
- JavaScript —— 局部变量和全局变量
JS的全局变量有3种声明方式: 1.Function 外 var v_myVar; 2.Function 内 v_myVar; 3.window.v_myVar window.v_myVar 全局变量 ...