CSDN周赛59期简要题解

news2024/12/25 16:35:02

本期题目相对比较友好,而且在比赛报名界面还提示了非编程题考察的章节——诚不欺我:

本期非编程题需要选手阅读的章节是第2章“逆向思考——从递推到递归”—2.3节“堆栈和队列:遍历的数据结构

选择和判断都考到了栈的数据结构,稍微有点基础知识找出正确答案并不难。而填空题也是最简单的二叉树的遍历问题。只不过一开始我还想回答“层序”,但填空后面紧跟着的“优先”二字,提示了我只能二选一,很显然,树的层序遍历就是广度优先遍历,填上“广度”二字即可。


编程题

两道编程题都不难,但是都有必须要被狠狠吐槽的点。

1. 坏掉的打字机

贝博士发明了一种能够自动输出数字并求和的打字机,但这台打字机出了一些故障,它除了输出数字以外还会随机地输出其他字符。艾小姐让贝博士不要着急,她写了一段程序,能够让这台打字机即使在这样的情况下也能输出正确答案。那么,你知道艾小姐的程序是怎么写的吗?

输入描述:单行文本(字符数小于100000)。

输出描述:提取该文件中所有的数字,并输出它们的和。如果结果为整数,则输出整数。如果结果为小数,则输出的小数不应该带有末尾的0(字符串中的数字在-999999到999999之间,且最多含有3位小数)。

输入样例:10.20.5.9.9.-8.22.,40.75

输出样例:57.63

字符串题,难点在于从一长串字符串中提取出所有合法的数字,再进行求和。关于合法的数字,本题的定义是:

  • 负数。很好理解,负号(-)在头部,且只有一个负号的数字。
  • 小数。比如 3.14、3.(这里小数点后面没有数字也算合法)、3.1000 (第一个槽点在此,虽然小数如题目所说未满三位,但是如果后面都是0,依然算是前面那个数的小数位)

之所以说上面的 3.1000 是个槽点,因为如果严格按照题目的要求(最多含有3位小数),那么3.1000 应该被解析成 3 和 1000 两个整数。这里故意写成 3.1000 却要解析成 3.1,唯一的作用就是恶心你。

如此,对于从一堆字符串中找到所有合法数字,最简单的办法无疑就是正则式了。按照题目字面意思,写成的正则式应该是 -?\d+\.?\d{0, 3} 。但是由于上面提到的“坑”,这个表达式找不出 3.1000,于是改写成 -?\d+\.?\d*,即不限制小数点后尾数,就能抓出所有数字了。

严格来说,这样并不符合题目的要求,比如如果真的有 3.1415 这样的数字,按照题目要求,应该是解析出 3 和 1415 才对。但所幸本题太水,而出题人好像故意留坑,从而没有考虑到这一点。

紧接着,就会遇到本题最大的槽点。上面这种方法只能通过 90%,另外 10% 的正确答案竟然是四位数!合着你告诉我所有数字“最多含有3位小数”,结果正确答案是4位数?!求求你告诉我一堆3位小数的数字是怎么通过相加得到4位小数的?虽然计算机的浮点数计算是存在误差的,但误差也不会误差到万分位这么高的位置吧?就算真的是因为误差,难道误差可以作为正确答案??

大写的无语。

当然,通过这一例的方法也很简单,保留4位小数即可,不再赘述。

2. 布尔零点计数

使一个布尔表达式的值为零的取值组合称为该表达式的一个布尔零点。

比如,布尔表达式A+B+C就只有一个零点,就是(A,B,C)的取值组合(0,0,0)。而布尔表达式A*B*C就有不止一个零点,(A,B,C)的取值组合为(0,0,1)或(1,1,0)都是它的零点。其中A、B、C都是布尔变量,而布尔变量只能取值0或1。

布尔表达式可以把布尔变量去掉而只保留运算符,称为布尔表达式的简写。如:+*(+)就是布尔表达式A*(B+C)的简写。

现在用|表示或运算,它有如下的真值表:

0|0=0
0|1=1
1|0=1
1|1=1

布尔表达式的优先级是:乘法运算优先于加法运算和或运算,但小括号可以改变优先级为“小括号中的内容优先”。

现给出只包含乘法运算和或运算的布尔表达式的简写,求表达式的零点计数。

输入描述:单行文本,表示布尔表达式的简写(字符数小于10000)。

输出描述:表达式的零点计数d(d>=0)。

输入样例:(|)*

输出样例:5

本题也不难,但是读题的时候就会发现第一个槽点:题目的乘法是用 \* 表示的。很显然,这是为了防止题目描述的字符被转义(*号在MD中有加粗的作用),但问题是接收到的表达式,是没有这个反斜杠(\)的,题目也没有对此进行说明。当然,这个问题也不大,稍微有点web经验的选手应该都能看得出来。但是,规范的题目不是应该尽可能避免歧义么?

其实本题还是挺巧妙的,结合了栈的数据结构,与DP的递推思想。但是,真的不难。

首先,由于计算是有优先级的,乘法(*)优先于或运算(|),而如果出现括号的话,先计算括号中的内容——这与数学表达式是相同的。而如果说到数学表达式,就很容易想到更符合计算机思想的——后缀表达式,也叫逆波兰表达式,我记得还有一期专门说过。

后缀表达式对计算机来说是没有优先级的(或者说不用考虑优先级),从左到右,依次计算下去,这样就容易递推了对不对?当然,后缀表达式用到了栈结构,而且是两个栈。这部分属于标准内容,感兴趣的同学可以自行搜索,背模板即可。

于是,只要将题目给出的表达式转换成后缀表达式,问题就迎刃而解了。

不过,在转换的过程中会碰到一个小问题:表达式里的布尔变量被省略了。比如 **| 和 *|* 其实是不同的表达式,但由于省略了布尔变量,如果“硬”转成后缀表达式,就都变成了 **|,显然是错误的。所以在转换为后缀表达式的同时,我们还需要将省略的布尔变量“补”回来。

但是,我们其实并不用真的把布尔变量补回来,因为我们要计算的是整个表达式最终结果为 0 的组合数,所以补回布尔变量并无意义,除非你想通过暴力穷举是填充每个位置的布尔变量。——复杂度将是恐怖的 O(2^{n}) 。

这个时候就可以借鉴一下 DP 的递推思想了。我们可以维护一个数组,只保存两个数字,表示“计算到目前为止,使得前面出现过的表达式(已转成后缀表达式)计算结果为 0 和为 1 的组合分别是多少”。这句话有点长,但其实不难理解:假设只有一个布尔变量,那它要么为 0,要么为 1,用数组可以表示为 (1, 1),表示它为 0 或为 1 的组合数各为 1。当它遇到第二个布尔变量(也用(1, 1)表示),分别进行乘法(*)和或运算(|)的结果是怎样的呢?

我们记第一个布尔变量为 a,第二个布尔变量为 b,二者计算结果为 c,则

  • 当进行乘法(*)计算时:c = [a[0]*b[0]+a[0]*b[1]+a[1]*b[0], a[1]*b[1]]
  • 当进行或运算(|)计算时:c = [a[0]*b[0], a[1]*b[0]+a[1]*b[1]+a[0]*b[1]]

大家可以自行体会一下。

想到了这一点,前面“补全”表达式的答案也清晰了,只要将布尔变量的位置放上一个(1,1)即可。然后将其转成后缀表达式,再用上面介绍的计算方法依次计算即可得到最终答案。当然,最终答案是包含了使表达式结果分别为 0 和为 1 的组合个数,我们只输出为 0 的组合数就好。

然鹅。。。最终将迎来本题的最后一个大坑。

单纯上面这种方法只能通过 80% 的用例,原因是,另外两个用例的答案数字太大,会造成溢出。而题目却并没有说明对于溢出的情况如何处理(同类题目一般都会要求结果对 1e9+7 取余)。而对于 Python 这种弱数据类型的语言来说,不存在溢出,所以直接得到的大数答案,虽然是正确的,却通不过。

解决办法就是将答案对 2^{32} 取模,模拟这个溢出的过程,只取溢出后的数字作为答案。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/673135.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【MySQL进阶】:子查询与HAVING/SELECT的完美结合

前言 ✨欢迎来到小K的MySQL专栏,本节将为大家带来MySQL子查询在HAVING/SELECT字句中使用、及相关子查询和WITH/EXISTS字句的讲解✨ 目录 前言一、在HAVING/SELECT字句中使用子查询二、相关子查询三、WITH/EXISTS、NOT EXISTS字句四、总结 一、在HAVING/SELECT字句中…

【Python 基础篇】Python 字典及字典常用函数

文章目录 导言一、字典的创建和访问二、字典的增删改查1、增加元素2、删除元素3、修改元素4、查找元素 三、字典常用函数及操作1、len()2、keys()3、values()4、items()5、字典的遍历 总结 导言 在Python中,字典(Dictionary)是一种无序的数据…

使用它或失去它!谷歌即将清理不活跃账号

如果你很长时间没有登录你的谷歌账号,最好尽快登录,否则你很可能会失去账号。 2023年5月16号,谷歌宣布,将开始删除至少两年不活跃的账号。 如果谷歌帐户至少两年未被使用或登录,可能会删除该帐户及其内容,包…

04. 青龙面板通知配置 邮箱 pushPlus 企业微信机器人(保姆级图文)

目录 1. qq邮箱通知2. pushPlus通知3. 企业微信机器人总结 欢迎关注 『青龙面板』 专栏,持续更新中 欢迎关注 『青龙面板』 专栏,持续更新中 1. qq邮箱通知 emailUser:填写你的邮箱 emailPass:填写邮箱密钥授权码 邮箱密钥获取教…

【从零开始学习JAVA | 第六篇】面向对象综合训练

目录 前言: 1.文字版格斗游戏: 2.对象数组1 前言: 前面我们已经讲解了JAVA面向程序对象思想的关键要素:封装。我们将利用本篇进行几个小型的练习,帮助我们更好的理解面向对象编程这种思想。 1.文字版格斗游戏&#x…

C++哈希表

目录 介绍哈希概念哈希冲突哈希函数解决哈希冲突 闭散列介绍线性探测二次探测负载因子 实现哈希表结构哈希函数元素查找插入元素删除元素 开散列介绍实现哈希表结构元素查找插入元素删除元素析构函数 介绍 哈希概念 了解过搜索二叉树与红黑树后,它们的结构特点主要…

8.批量消息发送与批量消息消费

highlight: arduino-light 4.4 批量消息 4.4.1 发送限制 生产者进行消息发送时可以一次发送多条消息,批量发送消息能显著提高传递小消息的性能。 不过需要注意以下几点: 批量发送的消息必须具有相同的Topic批量发送的消息必须具有相同的刷盘策略批量发送…

统计数组中非零元素的个数统计数组中每列中非零元素的个数统计数组中每行中非零元素的个数numpy.count_nonzero()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 统计数组中非零元素的个数 统计数组中每列中非零元素的个数 统计数组中每行中非零元素的个数 numpy.count_nonzero() 选择题 以下说法错误的是? import numpy as np anp.array([[0,1,2,3],[3,…

文件加密后怎么打开?打开加密文件的方法

当我们把重要文件加密后,可以有效地保护文件数据安全,那么文件加密后该怎么打开使用呢?下面我们就一起来了解一下吧。 EFS加密 作为Windows系统提供的文件加密方法,EFS加密并不需要密码。在我们使用加密时登录的系统账号时&…

使用HTML制作一个赛龙舟小游戏

在这个信息爆炸的时代,开发者们肩负着前所未有的责任与挑战,以屈原名言 路漫漫其修远兮,吾将上下而求索 为指引,使用HTML制作一个赛龙舟小游戏,以此激励广大开发者在技术征途上不断求索,追求极致。 一、前期…

忘记了谷歌Gmail账号名怎么办?用这种方法轻松找回谷歌邮箱地址

有些朋友以前注册过谷歌邮箱,但很久很久没有再去使用。 现在注册ChatGPT需要谷歌邮箱,于是打算把尘封已久的谷歌邮箱找出来,可是这时候你才发现,谷歌邮箱的账号名早已忘掉了。 今天重点来说说如何找回谷歌账号,希望能够…

ANTLR实战

ANTLR(Another Tool for Language Recognition)是目前非常活跃的语法生成工具,用Java语言编写,基于LL(∗)解析方式,使用自上而下的递归下降分析方法。ANTLR可以用来产生词法分析器、语法分析器和…

【运维知识进阶篇】zabbix5.0稳定版详解5(SNMP网络管理协议监控)

简单网络管理协议(SNMP)是专门设计用于在IP网络管理网络节点(服务器、工作站、路由器、交换机及HUBS网络枢纽等)的一种标准协议,它是一种应用层协议。 目录 SNMP三种版本 监控SNMP SNMP:OID和MIB介绍可以…

深度学习基于Resnet18的图像多分类--训练自己的数据集(超详细 含源码)

1.ResNet18原理 2.文件存储 一个样本存放的文件夹为dataset 下两个文件夹 train和test文件(训练和预测) 3.训练和测试的文件要相同。下面都分别放了 crane (鹤)、elephant(大象)、leopard(豹子) 4.编写预测的Python文件:code.py 跟dataset是同级路径。 5.code.p…

ROS从入门到精通2-7:Gazebo仿真之动态生成障碍物

目录 0 专栏介绍1 动态生成障碍应用场景2 基于Gazebo动态生成障碍2.1 spawn_model服务2.2 动态构造障碍物URDF2.3 请求服务与动态生成 3 实测演示 0 专栏介绍 本专栏旨在通过对ROS的系统学习,掌握ROS底层基本分布式原理,并具有机器人建模和应用ROS进行实…

CSS | 解决html中img标签图片底部存在空白缝隙的问题

目录 问题描述 原因分析 解决方案 写在最后 问题描述 在学习CSS的过程中&#xff0c;我们经常会遇到图片底侧存在空白缝隙的问题。 代码示例&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" />&l…

SpringCloudAlibaba之Sentinel源码分析--protoc-3.17.3-win64

Sentinel源码分析 文章目录 Sentinel源码分析1.Sentinel的基本概念1.1.ProcessorSlotChain1.2.Node1.3.Entry1.3.1.自定义资源1.3.2.基于注解标记资源 1.4.Context1.4.1.什么是Context1.4.2.Context的初始化1.4.2.1.自动装配1.4.2.2.AbstractSentinelInterceptor1.4.2.3.Contex…

【C++初阶】string类常见题目详解(一)—— 仅仅反转字母、字符串中的第一个唯一字母、字符串最后一个单词的长度、验证回文串、字符串相加

​ ​&#x1f4dd;个人主页&#xff1a;Sherry的成长之路 &#x1f3e0;学习社区&#xff1a;Sherry的成长之路&#xff08;个人社区&#xff09; &#x1f4d6;专栏链接&#xff1a;C初阶 &#x1f3af;长路漫漫浩浩&#xff0c;万事皆有期待 上一篇博客&#xff1a;【C初阶】…

【Python 基础篇】Python 集合及集合常用函数

文章目录 导言一、集合的创建和访问二、集合的常用函数len()add()remove()union()intersection()difference()issubset()issuperset()clear() 总结 导言 在Python中&#xff0c;集合&#xff08;Set&#xff09;是一种无序、不重复的数据类型&#xff0c;用于存储多个唯一的元…

HCIP网络笔记分享——广域网协议及BGP协议

第二部分 HCIA回顾一、广域网技术1、HDLC2、PPP3、PAP4、CHAP5、GRE6、运行路由协议 二、动态路由协议1、OSPF2、重发布3、路由策略3.1 抓流量3.2 具体过程 4、BGP 三、BGP边界网关协议1、BGP的数据包2、BGP的状态机3、BGP的工作过程4、BGP的路由黑洞问题5、BGP的防环问题6、BG…