当前位置: 首页 > news >正文

[表达式]真假计算

题目描述

有一棵树,不一定是二叉树。
所有叶子节点都是 True 或者 False
对于从上往下奇数层的非叶子节点是 and,偶数层非叶子节点为 or
树上每个节点的值是所有孩子节点的值进行该节点的运算操作。
判断一棵树能否砍掉,最快的方法就是从叶子节点一路“与” 和 “或” 到根节点,得到整颗树的真假值后进行决断。

树以简单的括号序列给出:上图可以描述为 ( ( A ( B C ) ) ( D E ) ) ((A(BC))(DE)) ((A(BC))(DE))

输入格式

数据包括若干组,每组数据包含一行一个字符串,输入 ( ) () () 表示结束。

输出格式

每组数据输出一行,包含:数据编号,点,空格,truefalse

样例

样例输入1:

((F(TF))(TF))
(TFT)
((TFT)T)
()

样例输出1

1. false
2. false
3. true

数据范围

对于 10 % 10\% 10% 的数据:每行只包含一对括号;
对于 30 % 30\% 30% 的数据:只有嵌套的括号,没有并列的括号;
对于 100 % 100\% 100% 的数据:测试数据少于 1000 1000 1000 组,字符串长度小于 32000 32000 32000

题解

直接进行递归,记录层数。

  1. 如果当前字符为 (,说明要进入下一层,进行下一层递归。
  2. 如果当前字符为 ),说明当前层结束,返回答案。
  3. 如果当前字符为 TF,计算答案。

判断结束判断字符串是不是 () 即可。

最后注意输入用 getchar,不要用 scanf

int dfs(int y){char x = ' ';int sum = -1;//答案while(x != '\n'){x = getchar();if(x == '\n'){//下一行return sum;}if(x == '('){//递归int u = dfs(y + 1);//计算答案if(sum == -1){sum = u;}else if(y % 2 == 0){sum = sum & u;}else{sum = sum | u;} continue;}if(x == ')'){//返回return sum;}//计算答案if(sum == -1){sum = (x == 'T');}else if(y % 2 == 0){sum = sum & (x == 'T');}else{sum = sum | (x == 'T');}}return sum;
}
int main(){int s = 0;//数据编号while(1){++ s;int u = dfs(-1);if(u == -1){return 0;} printf("%d. ", s);if(u){printf("true\n");}else{printf("false\n");}}return 0;
}
http://www.lryc.cn/news/468423.html

相关文章:

  • 记录一次线上环境svchost.exe antimalware service executable 进程占用CPU过高问题
  • Docker 部署 EMQX 一分钟极速部署
  • STL-常用容器-list
  • Lambda 架构
  • Windows电脑设置网络唤醒(Wake-on-LAN)
  • 前端项目构建流程
  • 支持国密算法的数字证书-国密SSL证书详解
  • 【EndNote使用教程】创建文献库、导入文献、文献分类
  • 双十一电容笔选哪个好?!西圣、益博思、吉玛仕电容笔实测对比!
  • 房地产网络安全:主要风险及缓解建议
  • 玩转大模型的第一步——提示词(Prompt)工程【抛砖篇】
  • 火山引擎数据飞轮线上研讨会即将开启,助力消费品牌双十一造爆款
  • 【python实战】利用代理ip爬取Alibaba海外版数据
  • FFMPEG录屏(20)--- 枚举macOS下的窗口和屏幕列表,并获取名称缩略图等信息
  • Redis 命令集 (超级详细)
  • Spring Cloud --- GateWay和Sentinel集成实现服务限流
  • python excel如何转成json,并且如何解决excel转成json时中文汉字乱码的问题
  • 【MySQL】实战篇—数据库设计与实现:根据需求设计数据库架构
  • [Python学习日记-53] Python 中的正则表达式模块 —— re
  • Unity编辑器 连接不到SteamVR问题记录
  • nginx 日志配置笔记
  • Java中的接口是什么?如何定义接口?
  • ​8.13TB高清卫星影像更新(WGS84坐标投影)
  • 【力扣】[Java版] 刷题笔记-21. 合并两个有序链表
  • 【Bug】RuntimeError: Engine loop has died
  • Labview写CIP协议
  • Redis批量获取缓存的方法
  • MySQL配置文件中server-id的作用是什么
  • Docker入门之构建
  • StarRocks数据库在SQL语句中解析JSON字符串