From 2020牛客NOIP赛前集训营-提高组(第二场)

传送门


分析

像我这么菜就只会模拟呀(考场CE全部爆零QWQ)

题意就是不断跳到下一个字母问总共跳的长度有多长,

首先用一个变量存下初始位置\(len-1\),(以下使用0开头,方便后面统计)

但显然暴力跳会T飞,必然存在循环节,长度为字母个数所贡献的答案为字符串长度

那么考虑高精度,求出有多少个循环节贡献的字符串长度,这里可以将星号视为所有字母,

关键就是余数部分,考虑用vector存下每个字母的位置,以及该位置下对应vector的位置,

那直接vector下标往后移余数位就可以了呀。


代码

#include <cstdio>
#include <cstring>
#include <cctype>
#include <vector>
#include <algorithm>
#define rr register
using namespace std;
const int mod=998244353,N=100011;
char S[N],T[N]; vector<int>K[27];
int Test,loc[N][2],c[N],len,LEN,ans;
inline void Mo(int &x,int y){x=x+y>=mod?x+y-mod:x+y;}
inline signed doit(int l,int r,int C1,int C2){
rr int g=0,s=0,tot=0,cho;
for (rr int i=l;i<=r;++i) c[i-l+1]=T[i]^48;
for (cho=r-l+1;!c[cho];--cho); --c[cho];
for (rr int i=cho+1;i<=r-l+1;++i) c[i]=9;
for (rr int i=l;i<=r;++i,g=s%C1)
s=g*10+c[i-l+1],c[++tot]=s/C1;
s=0;
for (rr int i=tot;i;--i)
s+=c[i]*C2,c[i]=s%10,s/=10;
for (rr int i=1;i<=tot;++i) s=(s*10ll+c[i])%mod;
Mo(ans,s);
return g;
}
signed main(){
scanf("%s%d",S,&Test),len=strlen(S);
for (rr int i=0;i<len;++i) K[S[i]^96].push_back(i),loc[i][0]=K[S[i]^96].size()-1;
for (rr int i=0;i<len;++i) K[0].push_back(i),loc[i][1]=i;
for (rr int LEN;Test;--Test){
scanf("%s",T),LEN=strlen(T),ans=0;
rr int l=0,r=0,beg=len-1,flag=1;
for (rr int f=0,now;l<LEN;l=++r){
if (T[l]=='*') T[l]=96,f=1; else f=0;
rr int G=T[l]^96,siz=K[G].size(),nxt;
if (!siz) {flag=0; break;}
if (l+1<LEN&&isdigit(T[l+1]))
for (;r+1<LEN&&isdigit(T[r+1]);++r);
if (K[G][siz-1]<=beg) nxt=K[G][0];
else nxt=*upper_bound(K[G].begin(),K[G].end(),beg);
if (beg<nxt) Mo(ans,nxt-beg),beg=nxt;
else Mo(ans,len-beg+nxt),beg=nxt;
if (l<r){
if (now=doit(l+1,r,siz,len)){
nxt=K[G][(loc[beg][f]+now)%siz];
if (beg<nxt) Mo(ans,nxt-beg),beg=nxt;
else Mo(ans,len-beg+nxt),beg=nxt;
}
}
}
if (!flag) printf("-1\n");
else printf("%d\n",ans);
}
return 0;
}

#高精度,模拟,vector#C 前缀的更多相关文章

  1. 2017年中国大学生程序设计竞赛-中南地区赛暨第八届湘潭市大学生计算机程序设计大赛题解&源码(A.高斯消元,D,模拟,E,前缀和,F,LCS,H,Prim算法,I,胡搞,J,树状数组)

    A------------------------------------------------------------------------------------ 题目链接:http://20 ...

  2. PTA笔记 堆栈模拟队列+求前缀表达式的值

    基础实验 3-2.5 堆栈模拟队列 (25 分) 设已知有两个堆栈S1和S2,请用这两个堆栈模拟出一个队列Q. 所谓用堆栈模拟队列,实际上就是通过调用堆栈的下列操作函数: int IsFull(Sta ...

  3. 高精度模板(Vector实现更加方便)

    计算的数long long 甚至更大的数据类型的都存不下的时候,应该怎么办 ? 解决方法 :我们可以把一个很大的数当做字符串进行处理,这时候就需要用到高精度. 话不多说,咱们边看代码边处理 : 加法 ...

  4. 绿书模拟day10 单词前缀

    [题目描述]一组单词是安全的,当且仅当不存在一个单词是另一个单词的前缀,这样才能保证数据不容易被误解,现在你手上有一个单词集合s,你需要计算有多少个自己是安全的.注意空集永远是安全的.[输入格式]第一 ...

  5. 2018.06.29 NOIP模拟 繁星(前缀和)

    繁星 [问题描述] 要过六一了,大川正在绞尽脑汁想送给小伙伴什么礼物呢.突然想起以前拍过一张夜空中的繁星的照片,这张照片已经被处理成黑白的,也就是说,每个像素只可能是两个颜色之一,白或黑.像素(x,y ...

  6. 2018.06.29 NOIP模拟 区间(前缀和差量)

    区间(interval.cpp) 时限:2000ms 空间限制:512MB [问题描述] 给出一个长度为 n 的序列 a[1]-a[n]. 给出 q 组询问,每组询问形如<x,y>< ...

  7. BestCoder 2nd Anniversary/HDU 5718 高精度 模拟

    Oracle Accepts: 599 Submissions: 2576 Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 262144/26 ...

  8. Tournament Chart【模拟+vector+map+string】

    Tournament Chart 传送门:链接  来源:UPC10889 题目描述 In 21XX, an annual programming contest, Japan Algorithmist ...

  9. 模拟vector

    实现了vector的模板,insert, erase, push_back, iterator #include<iostream> #include<string.h> #i ...

  10. 2018.10.02 NOIP模拟 聚会(前缀和)

    传送门 今天的签到题. 直接前缀和处理一下就秒了. 然而考试的时候智障用线段树维护被卡成了30分,交到OJ一测竟然有100? 搞得我都快生无可恋了. 如果用线段树来做可以类比这道题的写法,直接维护区间 ...

随机推荐

  1. 【系统选型】企业即时通讯(IM)软件调研及供应商对比评估

    企业即时通讯(IM)软件调研及供应商对比评估 1.概览 1.1 即时通讯 即时通讯(Instant messaging,简称IM)是一个终端服务,允许两人或多人使用网路即时的传递文字讯息.档案.语音与 ...

  2. python基础安装虚拟环境

    1.pip install virtualenv或者pip3 install virtualenv 2.在要存放虚拟环境的地方创建一个venv文件夹,用来存放所有创建的虚拟环境,方便查找与管理 3.m ...

  3. 02、NATS单节点部署

    接下来,我们一起看看如何部署一个单节点的 nats 服务器,这样后续学习 nats 的功能和特性的时候,会更加的清晰,那我们一起看看如何部署单节点的nats服务,后面在学习如何部署集群版的 nats. ...

  4. 如何将 IPhone 的文件导入 Linux

    如何将 IPhone 的文件导入 Linux 完全免费方案. 方法一: 使用 Koder 的 Local File Access 功能 这方法不需要在 Linux 端做任何配置. IPhone 端 安 ...

  5. DataGear 制作基于Vue2、Element UI前端框架的数据可视化看板

    DataGear 数据可视化看板内置了一些基本.简单的页面交互组件,当它们无法满足实际看板需求时,可以引入更流行和强大的前端框架. 本文以Vue2.Element UI前端框架为例,介绍如何制作具有更 ...

  6. 【Azure Logic App】使用Outlook.com发送邮件遇到429报错

    问题描述 在Logic App中使用 Outlook.com组件发送邮件,遇见了outlook connection报429的错误 {"error":{"code&quo ...

  7. 【Azure Developer】使用 Powershell az account get-access-token 命令获取Access Token (使用用户名+密码)

    问题描述 在上篇的文章中,我们使用了JAVA SDK,根据用户名和密码来获取Azure AD的Access Token,这节,我们将使用Powershell az 命令来获取Access Token. ...

  8. C#系列文章索引

    由于有读者说,是否可以讲C#一类的文章都统一在一起,因此我做了个索引文章置顶起来,以后C#相关文章也会同步更新到该索引文章下,以便查找 .Neter所应该彻底了解的委托 - RyzenAdorer - ...

  9. 多线程系列(十一) -浅析并发读写锁StampedLock

    一.摘要 在上一篇文章中,我们讲到了使用ReadWriteLock可以解决多线程同时读,但只有一个线程能写的问题. 如果继续深入的分析ReadWriteLock,从锁的角度分析,会发现它有一个潜在的问 ...

  10. Advanced .Net Debugging 3:基本调试任务(上)

    一.简介 这是我的<Advanced .Net Debugging>这个系列的第三篇文章.这个系列的每篇文章写的周期都要很长,因为每篇文章都是原书的一章内容(太长的就会分开写).再者说,原 ...