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

CF2121B Above the Clouds

CF2121B Above the Clouds - 洛谷

题目描述
给定一个长度为 n 的字符串 s,该字符串仅由小写拉丁字母组成。请判断是否存在三个非空字符串 a、b 和 c,使得:

  • a+b+c=s,即字符串 a、b、c 连接后的结果等于 s。
  • 字符串 b 是字符串 a+c 的子串,即 a 和 c 连接后的字符串包含 b 作为子串。

* 字符串 a 和 b 的连接定义为 a+b=a1​a2​…ap​b1​b2​…bq​,其中 p 和 q 分别为 a 和 b 的长度。例如,字符串 "code" 和 "forces" 的连接结果为 "codeforces"。
†如果字符串 a 可以通过从字符串 b 的开头删除若干(可能为零或全部)字符,以及从结尾删除若干(可能为零或全部)字符得到,则称 a 是 b 的子串。

输入格式
每组测试数据包含多组测试用例。第一行包含一个整数 t(1≤t≤104),表示测试用例的数量。接下来是每组测试用例的描述。
每组测试用例的第一行包含一个整数 n(3≤n≤105),表示字符串 s 的长度。
每组测试用例的第二行包含一个长度为 n 的字符串 s,仅包含小写拉丁字母。
保证所有测试用例中 n 的总和不超过 2×105。

输出格式
对于每组测试用例,如果存在满足条件的非空字符串 a、b、c,输出 "Yes";否则输出 "No"。
你可以以任意大小写输出答案。例如,"yes"、"YES" 等都会被识别为肯定答案。

输入输出样例
输入 #1
12
3
aaa
3
aba
3
aab
4
abca
4
abba
4
aabb
5
abaca
5
abcda
5
ababa
6
abcbbf
6
abcdaa
3
abb
输出 #1
Yes
No
Yes
No
Yes
Yes
Yes
No
Yes
Yes
Yes
Yes

说明 / 提示
在第一个测试用例中,存在唯一的非空字符串 a、b、c,使得 a+b+c=s。它们分别为 a="a",b="a",c="a"。a 和 c 的连接结果为 a+c="aa",b 是该字符串的子串。
在第六个测试用例中,可以选择 a="a",b="ab",c="b"。a 和 c 的连接结果为 a+c="ab",b 是该字符串的子串。
在第七个测试用例中,可以选择 a="ab",b="a",c="ca"。a 和 c 的连接结果为 a+c="abca",b 是该字符串的子串。
由 ChatGPT 4.1 翻译

思路:
贪心,枚举b子串长度为1即可,只要b子串被包含于a,c。就是yes。也就是说,b子串出现过的,除去首尾字符,再出现说明就是被包含a,c。所以记录是否出现两次的字符就可以了。

代码:
 

#include<bits/stdc++.h>
using namespace std;
int T;
int main(void)
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);cin >> T;while(T--){	int n;cin >> n;string s;cin >> s;s = " " + s;vector <bool> has(n+1);bool found = false;has[s[1] - 'a'] = true;has[s[n] - 'a'] = true;for(int i = 2 ; i <= n - 1 ; i++){if(has[s[i] - 'a']){found = true;break;}has[s[i] - 'a'] = true;}		if(found){cout << "YES" << '\n';}else{cout << "NO" << '\n';}}return 0;} 

http://www.dtcms.com/a/336712.html

相关文章:

  • 【Java】多线程Thread类
  • 什么是AIGC(人工智能生成内容)
  • 牛客周赛 Round 104(小红的树不动点)
  • 人工智能入门②:AI基础知识(下)
  • 计算机程序编程软件开发设计之node..js语言开发的基于Vue框架的选课管理系统的设计与实现、基于express框架的在线选课系统的设计与实现
  • STM32——软硬件I2C
  • Font Awesome Kit 使用详解
  • OTA升级
  • Vue Router 嵌套路由与布局系统详解:从新手到精通
  • 【牛客刷题】随机加减操作:两种高效解法详解(DFS记忆化搜索和动态规划集合更新法)
  • java序列化和反序列化
  • FX10/20 (CYUSB401X)开发笔记5 固件架构
  • 【个人项目】跑者天地—测试报告
  • 深入解析二维数组传参的本质
  • 运动场和光流-动手学计算机视觉17
  • 正则表达式实用面试题与代码解析专栏
  • 【Nginx】限流设置
  • 二三层交换转发业务~基础汇总
  • Mysql笔记-错误条件\处理程序
  • SSM从入门到实践:1.1 Spring框架概述与IoC容器入门
  • 堆(Heap):高效的优先级队列实现
  • duiLib 解决点击标题栏中按钮无响应问题
  • ROS2基础
  • C语言零基础第19讲:自定义类型—联合体和枚举
  • 解锁Java开发神器:XXL-Job从入门到精通
  • BT_LE_ADV_CONN_ONE_TIME 参数详解
  • Spring 创建 Bean 的 8 种主要方式
  • [创业之路-556]:创新的本质是赚不确定性带来的潜在价值,把不确定性逐步转化确定性,周而复始。
  • 产品设计.Ai产品经理
  • 48.Seata认识、部署TC服务、微服务集成