T1 整除

解题思路

答案就是 n 的每一个质因数的合法的答案数相乘(证明的话就。。。。)

但是复杂度显然不允许(虽然我们可以给指数取模水过去)。。

可以用积性筛(线性筛)利用质数筛出 \(x^m\) 然后就可以计算答案了

code

#include<bits/stdc++.h>
#define int long long
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=60,mod=998244353;
int n,task,m,cnt,c,ans,T,pri[10010],res[10010],s[N];
bool vis[10010];
int exgcd(int a,int b,int &x,int &y)
{
if(!b) return x=1,y=0,a;
int d=exgcd(b,a%b,x,y);
int z=y; x=y; y=z-(a/b)*y;
return d;
}
int power(int x,int y,int p=mod)
{
int temp=1; y%=p-1;
while(y)
{
if(y&1) temp=temp*x%p;
x=x*x%p; y>>=1;
}
return temp;
}
void solve()
{
c=read(); m=read(); ans=1;
for(int i=1;i<=c;i++) s[i]=read();
for(int i=1;i<=c;i++)
{
int sum=0;
for(int j=1;j<=s[i];j++)
if(vis[j]) res[j]=0;
else res[j]=power(j,m,s[i])%s[i];
for(int j=1;j<=s[i];j++)
{
if(res[j]==j%s[i]) sum++;
for(int k=1;k<=cnt&&pri[k]*j<=s[i];k++)
{
res[pri[k]*j]=res[pri[k]]*res[j]%s[i];
if(j%pri[k]==0) break;
}
}
ans=ans*sum%mod;
}
printf("%lld\n",ans);
}
void init()
{
for(int i=2;i<=10000;i++)
{
if(!vis[i]) pri[++cnt]=i;
for(int j=1;j<=cnt&&pri[j]*i<=10000;j++)
vis[i*pri[j]]=true;
}
}
signed main()
{
freopen("division.in","r",stdin); freopen("division.out","w",stdout);
init(); task=read(); T=read(); while(T--) solve();
return 0;
}

T2 糖果

解题思路

倍增 DP 。。

不难发现数据都是有周期的并且大于 \(m\) 的糖果可以直接视为只有 \(m\) 个。

然后我们就可以快速算出每一个数量的糖果的种类数了,然后进行倍增 DP。

设 \(g(i,j)\) 表示前 \(2^i\) 种糖果占 \(j\) 个位置的方案数:

\[g(i,j)=\sum\limits_{k=0}^jg(i-1,k)\times g(i-1,j-k)\times\binom{j}{k}
\]

然后对于相同数量的糖果我们所需要的种类数是一定了,因此用一个类似于上面的柿子加上背包的思想合并起来。

最后 DP 统计答案就好了

code

#include<bits/stdc++.h>
#define int long long
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=1e7+10,M=110,Lg=70,mod=998244353;
unordered_map<int,int> mp;
int T,s[N],n,m,a,b,p,las,maxn,p2[Lg],fac[M],ifac[M],cnt[N],ans[M][M],f[M][Lg][M],g[M][Lg][M],dep[M];
int power(int x,int y,int p=mod){int temp=1;while(y){if(y&1) temp=temp*x%p;x=x*x%p; y>>=1;}return temp;}
int C(int x,int y){return fac[x]*ifac[x-y]%mod*ifac[y]%mod;}
void solve(int lim)
{
for(int i=0;i<=lim;i++) f[lim][0][i]=1;
for(int i=1;i<=60;i++)
for(int j=0;j<=m;j++)
for(int k=0;k<=j;k++)
f[lim][i][j]=(f[lim][i][j]+f[lim][i-1][k]*f[lim][i-1][j-k]%mod*C(j,k))%mod;
int pos=lim; lim=cnt[pos]; g[pos][0][0]=1;
for(int i=60;i>=0;i--)
{
if(p2[i]>lim) continue; lim-=p2[i]; dep[pos]++;
for(int j=0;j<=m;j++)
for(int k=0;k<=j;k++)
g[pos][dep[pos]][j]=(g[pos][dep[pos]][j]+g[pos][dep[pos]-1][k]*f[pos][i][j-k]%mod*C(j,k))%mod;
}
}
signed main()
{
freopen("sugar.in","r",stdin); freopen("sugar.out","w",stdout);
n=read(); m=read(); maxn=s[1]=read(); a=read(); b=read(); p=read();
mp.insert(make_pair(s[1],1));
p2[0]=1; for(int i=1;i<=60;i++) p2[i]=p2[i-1]*2;
fac[0]=ifac[0]=1; for(int i=1;i<=m;i++) fac[i]=fac[i-1]*i%mod;
ifac[m]=power(fac[m],mod-2); for(int i=m-1;i>=1;i--) ifac[i]=ifac[i+1]*(i+1)%mod;
for(int i=2;i<=n;i++)
{
s[i]=(s[i-1]*a+b)%p+1; maxn=max(maxn,s[i]);
if(mp.find(s[i])!=mp.end())
{
las=mp.find(s[i])->second;
T=i-las; break;
}
mp.insert(make_pair(s[i],i));
}
if(!las) las=n+1; maxn=min(maxn,m);
for(int i=1;i<las;i++) cnt[min(m,s[i])]++;
if(T) for(int i=las;i<=las+T-1;i++) cnt[min(m,s[i])]+=(n-i)/T+1;
for(int i=1;i<=m;i++)
if(cnt[i]) solve(i);
else g[i][dep[i]][0]=1;
ans[0][0]=1;
for(int i=1;i<=maxn;i++)
for(int j=0;j<=m;j++)
for(int k=0;k<=j;k++)
ans[i][j]=(ans[i][j]+ans[i-1][j-k]*g[i][dep[i]][k]%mod*C(j,k))%mod;
printf("%lld",ans[maxn][m]);
return 0;
}

T3 打字机

解题思路

和题解的方法一样,对于前缀维护后缀的 \(h(i)\) 表示 \(S\) 长度为 \(i\) 的后缀和 \(T\) 的编辑距离。

那么 \(f(i,j,k)\) 表示考虑了 \(S\) 长度为 \(i\) 的前缀, \(T\) 长度为 \(j\) 的后缀,最大的 \(x\) 使得 \(x-h(x)\le k\)。

于是可以得到 DP 方程:

\[f(i,j,k)=min\{f(i-1,j,k)+1,f(i,j-1,k+1),f(i-1,j-1,k[S-i=T_j])\}
\]

code

#include<bits/stdc++.h>
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=1e5+10,M=22,base=20;
int T,n,m,l,r,len,f[N][M][M<<1];
char s[N],t[M];
void init()
{
memset(f,0x3f,sizeof(f));
for(int i=0;i<=n;i++)
for(int j=0;j<=m;j++)
fill(f[i][j]-m-1+base,f[i][j]+base-j-1+1,-1);
for(int i=base-m-1;i<=base+m;i++) f[0][0][i]=min(f[0][0][i],0);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
for(int k=base-m-1;k<=base+m;k++)
f[i][j][k]=min(f[i][j][k],min(f[i-1][j][k]+1,min(f[i][j-1][k+1],f[i-1][j-1][k-(s[i]==t[j])]+1)));
}
int solve()
{
l=read(); r=read(); len=r-l+1;
return len-(lower_bound(f[r][m]+base-m,f[r][m]+base+m+1,len)-f[r][m])+base;
}
signed main()
{
freopen("print.in","r",stdin); freopen("print.out","w",stdout);
scanf("%s%s",s+1,t+1); n=strlen(s+1); m=strlen(t+1);
init(); T=read(); while(T--) printf("%d\n",solve());
return 0;
}

T4 堆

大坑未补

NOIP模拟60的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  3. CH Round #48 - Streaming #3 (NOIP模拟赛Day1)

    A.数三角形 题目:http://www.contesthunter.org/contest/CH%20Round%20%2348%20-%20Streaming%20%233%20(NOIP模拟赛D ...

  4. NOIP模拟赛-2018.11.7

    NOIP模拟赛 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 编译之前另存一份,听说如果敲 ...

  5. NOIP模拟题汇总(加厚版)

    \(NOIP\)模拟题汇总(加厚版) T1 string 描述 有一个仅由 '0' 和 '1' 组成的字符串 \(A\),可以对其执行下列两个操作: 删除 \(A\)中的第一个字符: 若 \(A\)中 ...

  6. 2016-06-19 NOIP模拟赛

          2016-06-19 NOIP模拟赛 by coolyangzc 共3道题目,时间3小时 题目名 高级打字机 不等数列 经营与开发 源文件 type.cpp/c/pas num.cpp/c ...

  7. 2017-9-22 NOIP模拟赛[xxy][数论]

    XXY 的 的 NOIP 模拟赛 4 4 —— 数学专场 A Description定义 f(x)表示 x 的约数和,例:f(12)=1+2+3+4+6+12=28给出 x,y,求Σf(i),i∈[x ...

  8. 2014-10-31 NOIP模拟赛

        10.30 NOIp  模拟赛   时间 空间 测试点 评测方式 挖掘机(dig.*) 1s 256M 10 传统 黑红树(brtree.*) 2s 256M 10 传统 藏宝图(treas. ...

  9. 8.22 NOIP 模拟题

      8.22 NOIP 模拟题 编译命令 g++ -o * *.cpp gcc -o * *.c fpc *.pas 编译器版本 g++/gcc fpc 评测环境 位 Linux, .3GHZ CPU ...

  10. NOIP模拟 1

    NOIP模拟1,到现在时间已经比较长了.. 那天是6.14,今天7.18了 //然鹅我看着最前边缺失的模拟1,还是终于忍不住把它补上,为了保持顺序2345重新发布了一遍.. #   用  户  名   ...

随机推荐

  1. PyQt 快速使用

    1.安装 PyQt:使用 pip 命令在终端或命令提示符中运行以下命令: pip install pyqt5 2.创建 PyQt 应用程序:导入 PyQt5 模块并创建一个 QApplication ...

  2. 使用ISS服务器方式跑C#程序

    使用ISS服务器方式跑C#程序 VS2010,临时接了一个C#系统的小系统,需要本地调试跑一下 但是老是在conn.open提示06413,简单来说就是连接不上数据库 尝试了很多方法,最后还是决定配置 ...

  3. 力扣506(java)-相对名次(简单)

    题目: 给你一个长度为 n 的整数数组 score ,其中 score[i] 是第 i 位运动员在比赛中的得分.所有得分都互不相同 . 运动员将根据得分 决定名次 ,其中名次第 1 的运动员得分最高, ...

  4. 首次公开!阿里云开源PolarDB总体架构和企业级特性

    ​简介:在3月2日的阿里云开源 PolarDB 企业级架构发布会上,阿里云 PolarDB 内核技术专家北侠带来了主题为<PolarDB 总体架构设计和企业级特性>的精彩演讲. 在3月2日 ...

  5. 【CDS技术揭秘系列 01】阿里云CDS-OSS容灾大揭秘

    ​简介: 本文主要阐述 CDS 产品中 OSS 服务在容灾方面的部署形态以及实现的其本原理. 容灾功能可以保证用户一份数据在多个地方存在冗余备份,当某个机房出现极端异常(比如物理损毁)情况下,数据也不 ...

  6. WPF 通过 GifBitmapDecoder 调用 WIC 解析 Gif 和进行动画播放的简单方法

    本文告诉大家如何在 WPF 里,通过 GifBitmapDecoder 调用 WIC 层来解析 GIF 图片,然后采用动画的方式进行播放 在上一篇博客告诉大家,可以通过 GifBitmapDecode ...

  7. 如何拥有自己的专属GPT-本地部署目前最强大模型llama3

    你是不是苦于没法使用ChatGPT?或者访问了ChatGPT却没法使用GPT4?现在一切问题都可以解决了! 4月18日,Meta发布两款开源Llama 3 8B与Llama 3 70B模型,供外部开发 ...

  8. ESP32 I2C 总线主模式通信程序

    一.概述 这里主要是记录 ESP32 中进行 I2C 通行的基本程序,也可以说是 I2C 总线驱动程序,当然这里只是作为主模式,从模式我还没需要这个需求,以后有机会贴上.此笔记的主要目的是防止以后写 ...

  9. Codeforces Good Bye 2023

    A. 2023 正常签到. void solve() { int n, k, ok = 1; cin >> n >> k; int t = 2023; while(n --) ...

  10. Pinely Round 3 (Div. 1 + Div. 2)

    A 构造题,分两种情况考虑 上下都行,左右选一个 左右都行,上下选一个 void solve() { int n; cin >> n; vector<pair<int, int ...