zoj 1788 Quad Trees
先输入初始化MAP ,然后要根据MAP 建立一个四分树,自下而上建立,先建立完整的一棵树,然后根据四个相邻的格 值相同则进行合并,(这又是递归的伟大),逐次向上递归
四分树建立完后,再进行一深度优先遍历,生成二进制字符串,再转化为16进制输出
//#include "stdafx.h"
#include <string.h>
#include <string>
#include <queue>
#include <iostream>
#include "stdio.h"
using namespace std;
char MAP[512][512];
class quadtree//结点
{
public:
char value[3];// "00"->all 0 ,"01"->all 1,"1"->mixed
quadtree*q[4];//four children
quadtree()
{
q[0] = q[1] = q[2] = q[3] = 0;//initialize four children
}
bool operator == (const quadtree &p)const//运算符重载,
{
if (strcmp(value, "1") == 0 || strcmp(value, p.value) != 0)
return 0;
else
return 1;
} };
quadtree * DFS(int r, int c, int s)//r ,c 坐标,s长度
{
int i; bool f = 1;
quadtree*temp = new quadtree;
if (s==1)//最小长度,每一个格
{
temp->value[0] = '0';
temp->value[1] = MAP[r][c];
temp->value[2] = 0;//串结束符号?
return temp; }
s /= 2;//四分
temp->q[0] = DFS(r, c, s);
temp->q[1] = DFS(r, c + s, s);
temp->q[2] = DFS(r + s, c, s);
temp->q[3] = DFS(r + s, c + s, s);
for (i = 1; i < 4;i++)
{
if(!(*temp->q[0] == *temp->q[i]))//some of four children are different ,can not be merged
{
f = 0;
break;
}
}
if (f)//all children are same,merge
{
strcpy(temp->value, temp->q[0]->value);
for (i = 0; i < 4; i++)
{
delete temp->q[i]; temp->q[i] = 0;//delete all children
}
}
else// don't merge
{
strcpy(temp->value, "1");
}
return temp;
}
string BFS(quadtree*root)//广度遍历,生成二进制字符串
{
string s = "";
quadtree *cur = root;
queue <quadtree*> que;
que.push(root);
while (!que.empty())
{
cur = que.front();
que.pop();
s += cur->value;
for (int i = 0; i < 4; i++)
{
if (cur->q[i]->value != NULL)//有子才放进去!!!!!!!
que.push(cur->q[i]);
}
}
return s;
}
//////////////////////////////////////////////
//转化为16进制。。别人家的代码
char tohex(const string& str)
{
int ret = 0; for (int i = 0; i < 4; i++)
{
ret <<= 1;//左移 实现16进制的转化
if (str[i] == '1')
++ret;
} return (ret < 10) ? '0' + ret : 'A' + ret - 10;
}
string ToHex(const string& str)
{
string tmp = str;
string ret = ""; while (tmp.length() % 4 != 0)
tmp = "0" + tmp;
for (size_t i = 0; i < tmp.length(); i += 4)
ret += tohex(tmp.substr(i, 4));//substr 截取指定字符串,i为起始位置,4表示长度 return ret;
}
////这部分是别人家的 = =
///////////////////////////////////////////////////
int main()
{
string al;
int k, N;
scanf("%d", &k);//输入test 次数
while (k--)
{
scanf("%d", &N);
for (int i = 0; i < N; i++)//输入矩阵大小
{
for (int j = 0; j < N; j++)
{
cin >> MAP[i][j];// scanf("%c", &MAP[i][j]);//initialize the array } }
quadtree *root;
root =DFS(0, 0, N);//build a quardtree;
al = BFS(root);
//cout << al << endl;
cout << ToHex(al) << endl;
}
return 0;
}
zoj 1788 Quad Trees的更多相关文章
- [LeetCode] Quad Tree Intersection 四叉树相交
A quadtree is a tree data in which each internal node has exactly four children: topLeft, topRight, ...
- [LeetCode] Construct Quad Tree 建立四叉树
We want to use quad trees to store an N x N boolean grid. Each cell in the grid can only be true or ...
- LeetCode 427 Construct Quad Tree 解题报告
题目要求 We want to use quad trees to store an N x N boolean grid. Each cell in the grid can only be tru ...
- [LeetCode&Python] Problem 427. Construct Quad Tree
We want to use quad trees to store an N x N boolean grid. Each cell in the grid can only be true or ...
- leetcode 427. Construct Quad Tree
We want to use quad trees to store an N x N boolean grid. Each cell in the grid can only be true or ...
- 【LeetCode】558. Quad Tree Intersection 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...
- 【LeetCode】427. Construct Quad Tree 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...
- “等一下,我碰!”——常见的2D碰撞检测
转自:https://aotu.io/notes/2017/02/16/2d-collision-detection/ 在 2D 环境下,常见的碰撞检测方法如下: 外接图形判别法 轴对称包围盒(Axi ...
- elasticsearch 口水篇(6) Mapping 定义索引
前面我们感觉ES就想是一个nosql数据库,支持Free Schema. 接触过Lucene.solr的同学这时可能会思考一个问题——怎么定义document中的field?store.index.a ...
随机推荐
- jQuery获取隐藏文本域
[html] view plaincopyprint?//jquery获取隐藏域 <style type="text/css"> div{ width:1 ...
- Linq创建带命名空间、前缀、Soap格式的XML
关于XML,我也是刚接触,关于一般常见的XML,博客园.CSDN上的资料很多,对于不常见的带命名空间.前缀.Soap格式的XML的描述相对来说寥寥无几,上一篇我写到了对相对复杂的XML的读操作,下面说 ...
- Java数据结构之字符串模式匹配算法---KMP算法2
直接接上篇上代码: //KMP算法 public class KMP { // 获取next数组的方法,根据给定的字符串求 public static int[] getNext(String sub ...
- Dynamics AX 2012 R3 仓库和运输管理系列 - 仓库管理模块安装与配置
在AX 2012 R3版本中,新增了仓库和运输管理模块,同时提供了一个在移动设备上进行仓库管理工作的网站.在这个系列里,与Reinhard一起,了解仓库和运输管理模块吧. 需要注意的是 ...
- Sql Server 中一个非常强大的日期格式化函数
Sql Server 中一个非常强大的日期格式化函数Select CONVERT(varchar(100), GETDATE(), 0)-- 05 16 2006 10:57AMSelect CONV ...
- 【python】如何在某.py文件中调用其他.py内的函数
假设名为A.py的文件需要调用B.py文件内的C(x,y)函数 假如在同一目录下,则只需 import B if __name__ == "__main__": B.C(x,y) ...
- 关于js写全选的方法
思路:用一个变量来存储值,点击复选框来改变值: 代码 var num = 0; obj.onclick = function(){ if(this.checked == true){ for(var ...
- Git使用指南(2)——工作区,暂存区,版本库
1 工作区修改添加到暂存区 git add 2 暂存区提交到版本库 git commit 3 版本库更新到暂存区 git reset HEAD 4 删除暂存区文件 git rm --cached< ...
- Markdown工具之---Typora
在项目集成阶段中,接口文档是不可避免的,以往的我使用word编辑器编写接口文档,虽然word使用不是很熟练,但是只要在网上下载模板或者自己花时间搞定一个文档格式 基本能一劳永逸.但是还是会有很多问题存 ...
- (转载)The One Sign You Will Be Rich-(by Brian de Haaff Founder and CEO Aha! -- world's #1 product roadmap software)
When I was studying Philosophy at Berkeley, a friend told me that she could tell who was going to be ...