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 题解的更多相关文章

  1. 洛谷NOIp热身赛题解

    洛谷NOIp热身赛题解 A 最大差值 简单树状数组,维护区间和.区间平方和,方差按照给的公式算就行了 #include<bits/stdc++.h> #define il inline # ...

  2. 洛谷P2827 蚯蚓 题解

    洛谷P2827 蚯蚓 题解 题目描述 本题中,我们将用符号 ⌊c⌋ 表示对 c 向下取整. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓. 蛐蛐国里现 ...

  3. 洛谷P1816 忠诚 题解

    洛谷P1816 忠诚 题解 题目描述 老管家是一个聪明能干的人.他为财主工作了整整10年,财主为了让自已账目更加清楚.要求管家每天记k次账,由于管家聪明能干,因而管家总是让财主十分满意.但是由于一些人 ...

  4. [POI 2008&洛谷P3467]PLA-Postering 题解(单调栈)

    [POI 2008&洛谷P3467]PLA-Postering Description Byteburg市东边的建筑都是以旧结构形式建造的:建筑互相紧挨着,之间没有空间.它们共同形成了一条长长 ...

  5. [NOI 2020 Online] 入门组T1 文具采购(洛谷 P6188)题解

    原题传送门 题目部分:(来自于考试题面,经整理) [题目描述] 小明的班上共有 n 元班费,同学们准备使用班费集体购买 3 种物品: 1.圆规,每个 7 元. 2.笔,每支 4 元. 3.笔记本,每本 ...

  6. [洛谷P3948]数据结构 题解(差分)

    [洛谷P3948]数据结构 Description 最开始的数组每个元素都是0 给出n,opt ,min,max,mod 在int范围内 A: L ,R ,X 表示把[l,R] 这个区间加上X(数组的 ...

  7. [CodePlus 2017 11月赛&洛谷P4058]木材 题解(二分答案)

    [CodePlus 2017 11月赛&洛谷P4058]木材 Description 有 n棵树,初始时每棵树的高度为 Hi ,第 i棵树每月都会长高 Ai.现在有个木料长度总量为 S的订单, ...

  8. 洛谷P1189 SEARCH 题解 迭代加深

    题目链接:https://www.luogu.com.cn/problem/P1189 题目大意: 给你一个 \(n \times m\) 的矩阵,其中有一些格子可以走,一些各自不能走,然后有一个点是 ...

  9. 洛谷 P5221 Product 题解

    原题链接 庆祝!第二道数论紫题. 推式子真是太有趣了! \[\prod_{i=1}^n \prod_{j=1}^n \frac{\operatorname{lcm}(i,j)}{\gcd(i,j)} ...

随机推荐

  1. Git撤销&回滚操作(git reset 和 get revert)

    转自:https://blog.csdn.net/asoar/article/details/84111841 git的工作流 工作区:即自己当前分支所修改的代码,git add xx 之前的!不包括 ...

  2. 深入Pulsar Consumer的使用方式&源码分析

    原文链接 1.使用前准备 引入依赖: <dependency> <groupId>org.apache.pulsar</groupId> <artifactI ...

  3. 初探Spring Security

    Spring Security 简介 Spring Security是Spring家族中的一个组成框架,具有强大且高度可定制的身份验证和访问控制功能,致力于为Java应用程序提供身份的验证和授权 (先 ...

  4. Flink Data transformation(转换)

    Flink Data transformation 算子学习 1.Source:数据源,Flink在流处理和批处理上的source大概有4类: 基于本地集合的source.基于文件的source.基于 ...

  5. Go测试--子测试

    目录 简介 简单的例子 子测试命名规则 过滤筛选 子测试并发 总结 简介 简单的说,子测试提供一种在一个测试函数中执行多个测试的能力,比如原来有TestA.TestB和TestC三个测试函数,每个测试 ...

  6. Eclipse中安装配置Gradle

    Gradle是以Groovy语言为基础,面向Java应用为主.基于DSL(领域特定语言)语法的自动化构建工具. gradle对多工程的构建支持很出色,工程依赖是gradle的第一功能. gradle支 ...

  7. 🏆【Alibaba工具型技术系列】「EasyExcel技术专题」摒除OOM!让你的Excel操作变得更加优雅和安全

    前提概要 针对于后端开发者而言的,作为报表的导入和导出是一个很基础且有很棘手的问题!之前常用的工具和方案大概有这么几种: JXL(Java Excel API 工具服务),此种只支持xls的文件格式, ...

  8. GIS常用算法

    目录 1.常用算法 1.1.计算两经纬度点之间的距离 1.2.根据已知线段以及到起点距离,求目标点坐标 1.3.已知点.线段,求垂足 1.4.线段上距离目标点最近的点 1.5.点缓冲 1.6.点和面关 ...

  9. Python - 面向对象编程 - 小实战(2)

    需求 小明和小美都爱跑步 小明体重 75 公斤 小美体重 45 公斤 每次跑步会减肥 0.5 公斤 每次吃东西体重增加 1 公斤 需求分析 小明.小美都是一个具体的对象,他们都是人,所以应该抽象成人类 ...

  10. Selenium系列(22) - 通过selenium控制浏览器滚动条的几种方式

    如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...