2982. 找出出现至少三次的最长特殊子字符串 II

news2025/1/4 19:24:52

字典树思路

用字典树搞一下就好了,比如aaaaa :   a存5次 aa 4次以此类推~

字典树板子复习:P8306 【模板】字典树

这里这个清空方式 很好 因为很多时候memset   T

#include<iostream>
#include<cstring>
using namespace std;


const int N = 3e6+10;
int n,m;
string s;
int tire[N][70],cnt[N],idx;


void insert(){
	int p = 0;
	for(auto &t:s){
		int u;
		if(t>='a'&&t<='z')u = t-'a';
		else if(t>='A'&&t<='Z')u = t-'A'+ 27;
		else u = t -'0'+54;
		if(!tire[p][u]) tire[p][u]=++idx;
		p = tire[p][u];	
		cnt[p]++;
	}
}

int query(){
	int p=0;
	for(auto &t:s){
		int u;
		if(t>='a'&&t<='z')u = t-'a';
		else if(t>='A'&&t<='Z')u = t-'A'+ 27;
		else u = t -'0'+54;
		if(!tire[p][u]) return 0;
		p = tire[p][u];
	}
	
	return cnt[p];
}





void solve()
{
	cin>>n>>m;
	
	for(int i=0;i<=idx;i++)
	 for(int j=0;j<=65;j++)
	  tire[i][j] = 0;
	  
	for(int i=0;i<=idx;i++)cnt[i] = 0;
	idx = 0;
	while(n--)
	{
		cin>>s;insert();
	}
	
	while(m--){
		cin>>s;cout<<query()<<"\n";
	}
}


int main()
{
	int _;cin>>_;
	while(_--)solve();
}


本题代码;

const int N = 5e5+10;
int tr[N][27],cnt[N],idx;
class Solution {
public:

    string str;
    void insert(){
    	int ts = str.size();
        int p = 0;
        for(auto &t:str){
            int u = t - 'a';
            if(!tr[p][u])tr[p][u] = ++idx;
            p = tr[p][u];
            cnt[p]+=ts--;
        }

    }

    int find(char c){ 
        int p = 0;
        int t = 0;
        int u = c-'a';
        while(cnt[tr[p][u]]>=3){
        	t++;
        	p = tr[p][u];
        }
        return t;
    }

    int maximumLength(string s) {
        for(int i=0;i<=idx;i++)
         for(int j=0;j<=26;j++)
          tr[i][j] = 0;
        for(int i=0;i<=idx;i++)cnt[i] = 0;
        idx = 0;
        char c = s[0];
        int t = 1;
        for(int i=1;i<s.size();i++){
            if(s[i]!=c){
                str = "";
                while(t--)str+=c;
                insert();
                cout<<str<<"\n";
                c = s[i];
                t = 1;
            }else t++;
        }

        str = "";
        while(t--)str+=c;
        insert();
        cout<<str<<"\n";
        int ans = 0;
        for(char i='a';i<='z';i++) 
         ans = max(ans,find(i));
        if(ans)return ans;
        return -1;

    }
};


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

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

相关文章

1. MySQL 数据库

本章内容 关系型数据库基础 安装 MySQL 管理数据库和表 用户和权限管理 函数&#xff0c;存储过程&#xff0c;触发器和事件 MySQL 架构 存储引擎 服务器选项&#xff0c;系统和状态变量 优化查询和索引管理 锁和事务管理 日志管理 备份还原 MySQL 集群 压力测试…

Tensorflow2.0笔记 - tensor排序操作

本笔记主要记录sort,argsort,以及top_k操作&#xff0c;加上一个求Top K准确度的例子。 import tensorflow as tf import numpy as nptf.__version__#sort,argsort#对1维的tensor进行排序 tensor tf.random.shuffle(tf.range(10)) print(tensor) #升序 print("tf.sort(d…

晨曦记账本,你的账目整理专家

传统的账目明细记录和整理方式不仅费时费力&#xff0c;还容易出错。在数字化时代&#xff0c;【晨曦记账本】为你提供了一个全新的账目明细整理模式。它不仅能让你的账目明细变得井井有条&#xff0c;更能让你在管理财务的过程中得心应手。 所需工具&#xff1a; 一个【晨曦…

Ubuntu18编译jdk8源码

环境 系统 ubuntu18 Linux ubuntu 5.4.0-150-generic #167~18.04.1-Ubuntu SMP Wed May 24 00:51:42 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux jdk源码openjdk-8u41-src-b04-14_jan_2020.zip bootJdk jdk-8u391-linux-x64.tar.gz ps -e|grep ssh sudo apt-get install ssh…

BabylonJS 6.0文档 Deep Dive 摄像机(六):遮罩层和多相机纹理

1. 使用遮罩层来处理多个摄影机和多网格物体 LayerMask是分配给每个网格&#xff08;Mesh&#xff09;和摄像机&#xff08;Camera&#xff09;的一个数。它用于位&#xff08;bit&#xff09;级别用来指示灯光和摄影机是否应照射或显示网格物体。默认值为0x0FFFFFFF&#xff…

语义分割(2) :自定义Dataset和Dataloader

文章目录 1. 数据处理1.1 标签转换(json2mask和json2yolo)1.1.1 json2mask1.1.2 json2yolo 1.2 划分数据集1.2 不规范的标签图片处理1.3 批量修改图片后缀 2 自定义Dataset 和 Dataloader2.1 自定义Dataset2.1.1 数据增强(1) 对图像进行缩放并且进行长和宽的扭曲(2) 随机翻转图…

【C++中STL】map/multimap容器

map/multimap容器 map基本概念map构造和赋值map的大小和交换map插入和删除map的查找和统计 map排序 map基本概念 map中的所有元素都是pair对组&#xff0c;高效率&#xff0c;pair中的第一个元素为key&#xff08;键值&#xff09;&#xff0c;起到索引作用&#xff0c;第二个…

仅使用 Python 创建的 Web 应用程序(前端版本)第07章_商品列表

在本章中,我们将实现一个产品列表页面。 完成后的图像如下 创建过程与User相同,流程如下。 No分类内容1Model创建继承BaseDataModel的数据类Item2MockDB创建产品表并生成/添加虚拟数据3Service创建一个 ItemAPIClient4Page定义PageId并创建继承自BasePage的页面类5Applicati…

K8s-持久化(持久卷,卷申明,StorageClass,StatefulSet持久化)

POD 卷挂载 apiVersion: v1 kind: Pod metadata:name: random-number spec:containers:- image: alpinename: alpinecommand: ["/bin/sh","-c"]args: ["shuf -i 0-100 -n 1 >> /opt/number.out;"]volumeMounts:- mountPath: /optname: da…

Halcon指定区域的形状匹配

Halcon指定区域的形状匹配 文章目录 Halcon指定区域的形状匹配1.在参考图像中选择目标2.创建模板3.搜索目标 在这个实例中&#xff0c;会介绍如何根据选定的ROI选择合适的图像金字塔参数&#xff0c;创建包含这个区域的形状模板&#xff0c;并进行精确的基于形状模板的匹配。最…

08 BGP 华为官方文档 十一条选路原则

BGP 华为官方文档 十一条选路原则 丢弃下一跳不可达的路由 1&#xff09;比较“协议首选值-pref-val”属性&#xff0c;数值越大越好&#xff0c;默认值是0&#xff0c;只在本设备生效&#xff0c;不在网络中传递 2&#xff09;比较“本地优先级-local_pref”属性&#xff0c;…

初识数据库

数据库技术的基础术语 在学习数据库技术之前&#xff0c;我们先认识与该技术密切相关的基本术语&#xff0c;分别是数据库 (Database, DB)、数据库管理系统(Database Management System, DBMS)和数据库 系统(Database System, DBS)&#xff0c;具体介绍如下。 1. 数据库 数…

win10安装redis并配置加自启动(采用官方推荐unix子系统)

记录&#xff0c;为啥有msi安装包&#xff0c;还这么麻烦的用linux版本redis的安装方式&#xff0c;是因为从github上下载别人制作的msi报毒&#xff0c;还不止一处&#xff0c;这种链接数据库的东西&#xff0c;用别人加工过的&#xff0c;都报毒了还用就是傻逼了。 所以采用…

13.while条件循环语句 (4)

while条件循环语句是一种让脚本根据某些条件来重复执行命令的语句&#xff0c;它的循环结构往往在执行前并不确定最终执行的次数&#xff0c;完全不同于for循环语句中有目标、有范围的使用场景。 while循环语句通过判断条件测试的真假来决定是否继续执行命令&#xff0c;若条件…

IP 地址如何进行动态分配?

由于 IP 地址资源的有限性&#xff0c;大部分用户上网都是使用动态 IP 地址&#xff0c;而不是静态 IP 地址。动态 IP 地址指的是在需要的时候才进行 IP 地址分配的方式&#xff0c;而静态 IP 地址是固定分配一个 IP 地址&#xff0c;每次都用这一个地址。因此&#xff0c;IP 地…

AI PC的引擎 – 英特尔第 14 代处理器Meteor Lake架构分析

英特尔从2023年12月开始在笔记本电脑中发售首款 Meteor Lake 第 14 代 Core Ultra 芯片&#xff0c;开启新的“AI PC”时代。这款芯片采用了全新的架构&#xff0c;将CPU分为四块“瓷砖”&#xff08;tiles&#xff09;&#xff1a;CPU Tile&#xff0c;SoC Tile&#xff0c;Gr…

Python学习从0到1 day9 Python函数

苦难是花开的伏笔 ——24.1.25 函数 1.定义 函数&#xff1a;是组织好的&#xff0c;可重复使用的&#xff0c;用来实现特定功能的代码段 2.案例 在pycharm中完成一个案例需求&#xff1a;不使用内置函数len&#xff08;&#xff09;&#xff0c;完成字符串长度的计算 #统计字…

海外云手机三大优势

在全球化潮流下&#xff0c;企业因业务需求对海外手机卡等设备的需求不断攀升&#xff0c;推动了海外云手机业务的蓬勃发展。相较于自行置备手机设备&#xff0c;海外云手机不仅能够降低成本&#xff0c;还具备诸多优势&#xff0c;让我们深入探讨其中的三大黄金优势。 经济实惠…

Vulnhub靶机:FunBox 9

一、介绍 运行环境&#xff1a;Virtualbox 攻击机&#xff1a;kali&#xff08;10.0.2.15&#xff09; 靶机&#xff1a;FunBox 9&#xff08;10.0.2.37&#xff09; 目标&#xff1a;获取靶机root权限和flag 靶机下载地址&#xff1a;https://www.vulnhub.com/entry/funb…

NGINX如何实现rtmp推流服务

最近直播大火&#xff0c;直播推流软件遍地开花&#xff0c;那么用NGINX如何进行推流呢&#xff1f;下面我们就简单的介绍一下用NGINX的rtmp模块如何实现视频推流&#xff0c;我们主要从一下几点介绍&#xff1a; 推流拉流推流认证拉流认证 package mainimport ("fmt&qu…