#高精度,模拟,vector#C 前缀
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 前缀的更多相关文章
- 2017年中国大学生程序设计竞赛-中南地区赛暨第八届湘潭市大学生计算机程序设计大赛题解&源码(A.高斯消元,D,模拟,E,前缀和,F,LCS,H,Prim算法,I,胡搞,J,树状数组)
A------------------------------------------------------------------------------------ 题目链接:http://20 ...
- PTA笔记 堆栈模拟队列+求前缀表达式的值
基础实验 3-2.5 堆栈模拟队列 (25 分) 设已知有两个堆栈S1和S2,请用这两个堆栈模拟出一个队列Q. 所谓用堆栈模拟队列,实际上就是通过调用堆栈的下列操作函数: int IsFull(Sta ...
- 高精度模板(Vector实现更加方便)
计算的数long long 甚至更大的数据类型的都存不下的时候,应该怎么办 ? 解决方法 :我们可以把一个很大的数当做字符串进行处理,这时候就需要用到高精度. 话不多说,咱们边看代码边处理 : 加法 ...
- 绿书模拟day10 单词前缀
[题目描述]一组单词是安全的,当且仅当不存在一个单词是另一个单词的前缀,这样才能保证数据不容易被误解,现在你手上有一个单词集合s,你需要计算有多少个自己是安全的.注意空集永远是安全的.[输入格式]第一 ...
- 2018.06.29 NOIP模拟 繁星(前缀和)
繁星 [问题描述] 要过六一了,大川正在绞尽脑汁想送给小伙伴什么礼物呢.突然想起以前拍过一张夜空中的繁星的照片,这张照片已经被处理成黑白的,也就是说,每个像素只可能是两个颜色之一,白或黑.像素(x,y ...
- 2018.06.29 NOIP模拟 区间(前缀和差量)
区间(interval.cpp) 时限:2000ms 空间限制:512MB [问题描述] 给出一个长度为 n 的序列 a[1]-a[n]. 给出 q 组询问,每组询问形如<x,y>< ...
- BestCoder 2nd Anniversary/HDU 5718 高精度 模拟
Oracle Accepts: 599 Submissions: 2576 Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 262144/26 ...
- Tournament Chart【模拟+vector+map+string】
Tournament Chart 传送门:链接 来源:UPC10889 题目描述 In 21XX, an annual programming contest, Japan Algorithmist ...
- 模拟vector
实现了vector的模板,insert, erase, push_back, iterator #include<iostream> #include<string.h> #i ...
- 2018.10.02 NOIP模拟 聚会(前缀和)
传送门 今天的签到题. 直接前缀和处理一下就秒了. 然而考试的时候智障用线段树维护被卡成了30分,交到OJ一测竟然有100? 搞得我都快生无可恋了. 如果用线段树来做可以类比这道题的写法,直接维护区间 ...
随机推荐
- 【系统选型】企业即时通讯(IM)软件调研及供应商对比评估
企业即时通讯(IM)软件调研及供应商对比评估 1.概览 1.1 即时通讯 即时通讯(Instant messaging,简称IM)是一个终端服务,允许两人或多人使用网路即时的传递文字讯息.档案.语音与 ...
- python基础安装虚拟环境
1.pip install virtualenv或者pip3 install virtualenv 2.在要存放虚拟环境的地方创建一个venv文件夹,用来存放所有创建的虚拟环境,方便查找与管理 3.m ...
- 02、NATS单节点部署
接下来,我们一起看看如何部署一个单节点的 nats 服务器,这样后续学习 nats 的功能和特性的时候,会更加的清晰,那我们一起看看如何部署单节点的nats服务,后面在学习如何部署集群版的 nats. ...
- 如何将 IPhone 的文件导入 Linux
如何将 IPhone 的文件导入 Linux 完全免费方案. 方法一: 使用 Koder 的 Local File Access 功能 这方法不需要在 Linux 端做任何配置. IPhone 端 安 ...
- DataGear 制作基于Vue2、Element UI前端框架的数据可视化看板
DataGear 数据可视化看板内置了一些基本.简单的页面交互组件,当它们无法满足实际看板需求时,可以引入更流行和强大的前端框架. 本文以Vue2.Element UI前端框架为例,介绍如何制作具有更 ...
- 【Azure Logic App】使用Outlook.com发送邮件遇到429报错
问题描述 在Logic App中使用 Outlook.com组件发送邮件,遇见了outlook connection报429的错误 {"error":{"code&quo ...
- 【Azure Developer】使用 Powershell az account get-access-token 命令获取Access Token (使用用户名+密码)
问题描述 在上篇的文章中,我们使用了JAVA SDK,根据用户名和密码来获取Azure AD的Access Token,这节,我们将使用Powershell az 命令来获取Access Token. ...
- C#系列文章索引
由于有读者说,是否可以讲C#一类的文章都统一在一起,因此我做了个索引文章置顶起来,以后C#相关文章也会同步更新到该索引文章下,以便查找 .Neter所应该彻底了解的委托 - RyzenAdorer - ...
- 多线程系列(十一) -浅析并发读写锁StampedLock
一.摘要 在上一篇文章中,我们讲到了使用ReadWriteLock可以解决多线程同时读,但只有一个线程能写的问题. 如果继续深入的分析ReadWriteLock,从锁的角度分析,会发现它有一个潜在的问 ...
- Advanced .Net Debugging 3:基本调试任务(上)
一.简介 这是我的<Advanced .Net Debugging>这个系列的第三篇文章.这个系列的每篇文章写的周期都要很长,因为每篇文章都是原书的一章内容(太长的就会分开写).再者说,原 ...