洛谷 P7541 DOBRA 题解
hhh... 我又来写题解了
solution
题意简化
一个字符串,将所有的 _ 替换成大写字母,使结果字符串符合要求:
1、不包含三个连续 元音 或 辅音 字母;
2、字符串中至少有一个 L 。
求最终字符串可能的个数。
看到这道题,即想到了万能的算法——搜索。
从下标 \(0\) 开始,枚举每一个字母。
由于每次枚举的字母与后面的枚举无关,所以这样搜索不会出现重复的终串。
在枚举结束时使用 check 检测是不是合法终串,如果是就是一种情况。
注意:char 数组不会克隆,需要回溯。
#include#include<bits/stdc++.h>
using namespace std;
int yy[127];
int check(char ns[])
{
bool flag=0;
for(int i=0,len=strlen(ns);i<len-2;i++)
{
if((yy[ns[i]]==1&&yy[ns[i+1]]==1&&yy[ns[i+2]]==1)
||
((!yy[ns[i]])&&(!yy[ns[i+1]])&&(!yy[ns[i+2]]))) return -1;
if(!flag&&(ns[i]=='L'||ns[i+1]=='L'||ns[i+2]=='L')) flag=true;
}
return flag;
}
long long dfs(int i,char ns[])
{
if(i==strlen(ns)) return max(check(ns),0);
if(check(ns)==-1) return 0;
if(ns[i]!='_') return dfs(i+1,ns); //这里可优化 ;;虽然对结果没啥影响
long long ans=0;
for(char ch='A';ch<='Z';ch++)
{
ns[i]=ch;
ans+=dfs(i+1,ns);
}
ns[i]='_';
return ans;
}
int main()
{
//init
yy['A']=yy['E']=yy['I']=yy['O']=yy['U']=1;
yy['_']=-1;
char chr[1001];
scanf("%s",chr);
cout<<dfs(0,chr);
return 0;
}1
可惜,只会拿到可怜的 \(30\%\) 的分数。
先来算算时间复杂度吧。
对于每次操作,都有每个 _ 需要枚举 \(26\) 次,保证最多有 \(10\) 个,所以枚举次数最少 \(10^{26}\) 次方,超时是稳稳的。
所以如何减少时间复杂度呢?
我们可以发现,这道题实际上辅音字母之间并没有区别。同理,对于元音字母也是如此。
所以,可以每次只枚举两次,对于辅音字母的结果乘 \(26-5=21\);元音字母的结果乘 \(5\)。
还有一点要注意,由于 L 会影响结果,所以需要特殊考虑。
总共 \(3\) 次,枚举次数降为 \(10^3\) ,AC 稳稳的。
AC Code:
#include<bits/stdc++.h>
using namespace std;
int yy[127];
int check(char ns[])
{
bool flag=0;
for(int i=0,len=strlen(ns);i<len-2;i++)
{
if((yy[ns[i]]==1&&yy[ns[i+1]]==1&&yy[ns[i+2]]==1)
||
((!yy[ns[i]])&&(!yy[ns[i+1]])&&(!yy[ns[i+2]]))) return -1;
if(!flag&&(ns[i]=='L'||ns[i+1]=='L'||ns[i+2]=='L')) flag=true;
}
return flag;
}
long long dfs(int i,char ns[])
{
int len=strlen(ns);
while(ns[i]!='_'&&i<len) i++; //可优化递归层数,可惜只有100,没啥用
if(i==len) return max(check(ns),0);
if(check(ns)==-1) return 0;
long long ans=0;
ns[i]='A'; //这里泛指元音字母
ans+=dfs(i+1,ns)*5;
ns[i]='B'; //这里泛指辅音字母
ans+=dfs(i+1,ns)*20; //将 L 特殊考虑,21-1 即为 20
ns[i]='L';
ans+=dfs(i+1,ns);
ns[i]='_';
return ans;
}
int main()
{
//init
yy['A']=yy['E']=yy['I']=yy['O']=yy['U']=1;
yy['_']=-1;
char chr[1001];
scanf("%s",chr);
cout<<dfs(0,chr);
return 0;
}
从 9 s 降到 30ms,质的提升啊!
求过!
洛谷 P7541 DOBRA 题解的更多相关文章
- 洛谷NOIp热身赛题解
洛谷NOIp热身赛题解 A 最大差值 简单树状数组,维护区间和.区间平方和,方差按照给的公式算就行了 #include<bits/stdc++.h> #define il inline # ...
- 洛谷P2827 蚯蚓 题解
洛谷P2827 蚯蚓 题解 题目描述 本题中,我们将用符号 ⌊c⌋ 表示对 c 向下取整. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓. 蛐蛐国里现 ...
- 洛谷P1816 忠诚 题解
洛谷P1816 忠诚 题解 题目描述 老管家是一个聪明能干的人.他为财主工作了整整10年,财主为了让自已账目更加清楚.要求管家每天记k次账,由于管家聪明能干,因而管家总是让财主十分满意.但是由于一些人 ...
- [POI 2008&洛谷P3467]PLA-Postering 题解(单调栈)
[POI 2008&洛谷P3467]PLA-Postering Description Byteburg市东边的建筑都是以旧结构形式建造的:建筑互相紧挨着,之间没有空间.它们共同形成了一条长长 ...
- [NOI 2020 Online] 入门组T1 文具采购(洛谷 P6188)题解
原题传送门 题目部分:(来自于考试题面,经整理) [题目描述] 小明的班上共有 n 元班费,同学们准备使用班费集体购买 3 种物品: 1.圆规,每个 7 元. 2.笔,每支 4 元. 3.笔记本,每本 ...
- [洛谷P3948]数据结构 题解(差分)
[洛谷P3948]数据结构 Description 最开始的数组每个元素都是0 给出n,opt ,min,max,mod 在int范围内 A: L ,R ,X 表示把[l,R] 这个区间加上X(数组的 ...
- [CodePlus 2017 11月赛&洛谷P4058]木材 题解(二分答案)
[CodePlus 2017 11月赛&洛谷P4058]木材 Description 有 n棵树,初始时每棵树的高度为 Hi ,第 i棵树每月都会长高 Ai.现在有个木料长度总量为 S的订单, ...
- 洛谷P1189 SEARCH 题解 迭代加深
题目链接:https://www.luogu.com.cn/problem/P1189 题目大意: 给你一个 \(n \times m\) 的矩阵,其中有一些格子可以走,一些各自不能走,然后有一个点是 ...
- 洛谷 P5221 Product 题解
原题链接 庆祝!第二道数论紫题. 推式子真是太有趣了! \[\prod_{i=1}^n \prod_{j=1}^n \frac{\operatorname{lcm}(i,j)}{\gcd(i,j)} ...
随机推荐
- 数据库存储图片相对路径使用问题,配置tomcat的server.xml文件
我想从前端读取路径的时候,必须输入相对路径+根路径,但是我数据库中存的相对路径 接下来讲解如何通过相对路径获得照片 首先我们需要在tomcat的server.xml文件中更改属性,eslipse可以直 ...
- springmvc框架(Spring SpringMVC, Hibernate整合)
直接干货 model 考虑给用户展示什么.关注支撑业务的信息构成.构建成模型. control 调用业务逻辑产生合适的数据以及传递数据给视图用于呈献: view怎样对数据进行布局,以一种优美的方式展示 ...
- Spring Boot +Vue 项目实战笔记(三):数据库的引入
这一篇的主要内容是引入数据库并实现通过数据库验证用户名与密码. 一.引入数据库 之前说过数据库的采用是 MySQL,算是比较主流的选择,从性能和体量等方面都比较优秀,当然也有一些弊端,但数据库不是我们 ...
- C# - 习题03_分析代码写出结果A.X、B.Y
时间:2017-08-23 整理:byzqy 题目:分析代码,写出程序的输出结果: 文件:Program.cs 1 using System; 2 3 namespace Interview2 4 { ...
- vue+Element-ui 的 el-cascader 做高德地图的省市区三级联动并且是异步加载,点击省市区跳转到对应的区(地图可以通过后端返回的点进行标点)
// 完整版高德地图,可以复制代码直接使用 index.html <script type="text/javascript" src="https://webap ...
- Springboot 整合通用mapper和pagehelper展示分页数据(附github源码)
简介 springboot 设计目的就是为了加速开发,减少xml的配置.如果你不想写配置文件只需要在配置文件添加相对应的配置就能快速的启动的程序. 通用mapp 通用mapper只支持对单表的操作,对 ...
- Typora代码块配色和标题自带序号的实现代码
Typora代码块配色和标题自带序号的实现代码 先打开主题文件夹 文件>偏好设置>外观>打开主题文件夹 然后编辑base.user.css(如果没有就新建一个)文件 /*标题自动添加 ...
- You-Get开源在线下载神器,搭配python更加丝滑(文中案例演示)
大家好,我是辰哥 今天给大家介绍一个号称可以下载全网视频.音频.图像的开源库 --you-get you-get 这里说全网可能一点夸张,但如果实际上去使用you-get下载媒体文件(视频.音频.图像 ...
- CentOS管理firewalld防火墙
1.查看防火墙某个端口是否开放 firewall-cmd --query-port=80/tcp 2.开放防火墙端口80 firewall-cmd --zone=public --add-port=8 ...
- echo -e 命令详解
echo在php中是输入那么在linux中是不是也是输入呢,当然echo在linux也是输入不过它的用法比php强大多了可以带参数及一些东西,下面我们来看一篇关于linux echo命令介绍及-n.- ...