UVA 297 Quadtrees 好像不是很难。又好像不是很简单

2024-06-01 22:32

本文主要是介绍UVA 297 Quadtrees 好像不是很难。又好像不是很简单,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

UVA 297 Quadtrees

题目的意思挺好理解的,输入两颗四叉树,按照p为不空不满,f为满,e为空,按照先序输入, 把两颗四叉树合并起来,计算出新树的值。。

思路:首先把2个字符串处理,变成2个二维数组存放,然后在通过二维数组,就能查找到每个位置的结点相加之后的结果,要注意,如果四叉树4个分叉都为f,那么处理为结点为f,结点之后全部删除。

代码
#include <stdio.h>
#include <string.h>
#include <math.h>int t;
char a[1366];
char b[1366];
int num;
int lena, lenb, lenc;
int l;
int la, lc;
char aa[6][1111];
char bb[6][1111];
char cc[6][1111];void tra(char *a, char aa[][1111], int len, int x, int n, int m)
{if (la == len){return;}if (n % 4 == 0 && a[la - 1] != 'p' && la != 0){tra(a, aa, len, x - 1, n / 4, m / 4);}if (a[la] == 'p'){aa[x][n] = a[la];la ++;tra(a, aa, len, x + 1, n * 4, m * 4);}if (a[la] == 'f'){aa[x][n] = a[la];la ++;tra(a, aa, len, x, n + 1 , m + 1);}if (a[la] == 'e'){aa[x][n] = a[la];la ++;tra(a, aa, len, x, n + 1, m + 1);}
}int main()
{scanf("%d", &t);getchar();while (t --){l = 0;num = 0;memset(a, 0, sizeof(a));memset(b, 0, sizeof(b));memset(cc, 0, sizeof(cc));memset(aa, 0, sizeof(aa));memset(bb, 0, sizeof(bb));gets(a);gets(b);lena = strlen(a);lenb = strlen(b);la = 0;tra(a, aa, lena, 0, 0, 0);la = 0;tra(b, bb, lenb, 0, 0, 0);for (int i = 5; i >= 0; i --)for (int j = 0; j < pow(4, i); j ++){if (i != 5){if (cc[i + 1][j * 4] == 'f' && cc[i + 1][j * 4 + 1] == 'f' && cc[i + 1][j * 4 + 2] == 'f' && cc[i + 1][j * 4+ 3] == 'f'){cc[i][j] = 'f';cc[i + 1][j * 4] = cc[i + 1][j * 4 + 1] = cc[i + 1][j * 4 + 2] = cc[i + 1][j * 4 + 3] = '\0';continue;}}if (aa[i][j] == 'f' || bb[i][j] == 'f'){cc[i][j] = 'f';cc[i + 1][j * 4] = cc[i + 1][j * 4 + 1] = cc[i + 1][j * 4 + 2] = cc[i + 1][j * 4 + 3] = '\0';continue;}if (aa[i][j] == 'e'){cc[i][j] = bb[i][j];continue;}if (bb[i][j] == 'e'){cc[i][j] = aa[i][j];continue;}if (aa[i][j] == 'p' && bb[i][j] == 'p'){cc[i][j] = 'p';continue;}if (aa[i][j] == '\0' && bb[i][j] != '\0'){cc[i][j] = bb[i][j];continue;}if (aa[i][j] != '\0' && bb[i][j] == '\0'){cc[i][j] = aa[i][j];continue;}}for (int i = 5; i >= 0; i --)for (int j = 0; j < pow(4, i); j ++){if (cc[i][j] == 'f')num += (1024 / pow(4, i));}printf("There are %d black pixels.\n", num);}return 0;
}


这篇关于UVA 297 Quadtrees 好像不是很难。又好像不是很简单的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1022275

相关文章

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

回调的简单理解

之前一直不太明白回调的用法,现在简单的理解下 就按这张slidingmenu来说,主界面为Activity界面,而旁边的菜单为fragment界面。1.现在通过主界面的slidingmenu按钮来点开旁边的菜单功能并且选中”区县“选项(到这里就可以理解为A类调用B类里面的c方法)。2.通过触发“区县”的选项使得主界面跳转到“区县”相关的新闻列表界面中(到这里就可以理解为B类调用A类中的d方法

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用。如果你看不懂,请留言。 完整代码: <!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><ti

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

宝塔面板部署青龙面板教程【简单易上手】

首先,你得有一台部署了宝塔面板的服务器(自己用本地电脑也可以)。 宝塔面板部署自行百度一下,很简单,这里就不走流程了,官网版本就可以,无需开心版。 首先,打开宝塔面板的软件商店,找到下图这个软件(Docker管理器)安装,青龙面板还是安装在docker里,这里依赖宝塔面板安装和管理docker。 安装完成后,进入SSH终端管理,输入代码安装青龙面板。ssh可以直接宝塔里操作,也可以安装ssh连接

XMG Quartz2D的简单使用

// //  Quratz2DView.m //  Quartz2D // //  Created by 王宁 on 16/5/6. //  Copyright © 2016年 ylshmacmini. All rights reserved. // #import "Quratz2DView.h" //Quartz@2D是一个二维绘图引擎,同时支

网页脚本输入这么简单

如何在网页中进行脚本操作呢? 研究了一下,很简单,用google浏览器的Console直接操作javaScript。思路: Created with Raphaël 2.1.0 开始 输入(如何输入) 点击(如何点击) 结束 下面是,通过脚本刷直播屏的实现,直接在Console输入即可 var words=new Arra

Linux网络编程之简单并发服务器

1.概念 与前面介绍的循环服务器不同,并发服务器对服务请求并发处理。而循环服务器只能够一个一个的处理客户端的请求,显然效率很低. 并发服务器通过建立多个子进程来实现对请求的并发处理,但是由于不清楚请求客户端的数目,因此很难确定子进程的数目。因此可以动态增加子进程与事先分配的子进程相结合的方法来实现并发服务器。 2. 算法流程 (1)TCP简单并发服务器:     服务器子进程1:

IntelliJ IDEA svn chekout 项目发生svn不是内部命令

错误信息: 1、Cannot checkout from svn: 'C:\Program' 不是内部或外部命令,也不是可运行的程序 或批处理文件 2、server ssl cerificate verification failed:certificate issued for a different hostname.issuer is not trusted (服务器ssl证书验证失败

UVA - 12206 Stammering Aliens (hash)

这题其实很容易想到2分长度,关键是2分后,怎么判断出现最多次的串是否》=m次了。这里需要用到hash来处理。 对于一个字符串   H[i] =H[i+1]*131+s[i]  ;其中 H[n]=0;那么对于一个长度为L的串 ,hanh[i,l]=H[i]-H[i+L]*x^L ; 这样记录每个字符串的hash值,然后再处理起来就比较简单了。 VIEW CODE #include<