NOIP模拟60
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\) 个位置的方案数:
\]
然后对于相同数量的糖果我们所需要的种类数是一定了,因此用一个类似于上面的柿子加上背包的思想合并起来。
最后 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 方程:
\]

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的更多相关文章
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- CH Round #48 - Streaming #3 (NOIP模拟赛Day1)
A.数三角形 题目:http://www.contesthunter.org/contest/CH%20Round%20%2348%20-%20Streaming%20%233%20(NOIP模拟赛D ...
- NOIP模拟赛-2018.11.7
NOIP模拟赛 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 编译之前另存一份,听说如果敲 ...
- NOIP模拟题汇总(加厚版)
\(NOIP\)模拟题汇总(加厚版) T1 string 描述 有一个仅由 '0' 和 '1' 组成的字符串 \(A\),可以对其执行下列两个操作: 删除 \(A\)中的第一个字符: 若 \(A\)中 ...
- 2016-06-19 NOIP模拟赛
2016-06-19 NOIP模拟赛 by coolyangzc 共3道题目,时间3小时 题目名 高级打字机 不等数列 经营与开发 源文件 type.cpp/c/pas num.cpp/c ...
- 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 ...
- 2014-10-31 NOIP模拟赛
10.30 NOIp 模拟赛 时间 空间 测试点 评测方式 挖掘机(dig.*) 1s 256M 10 传统 黑红树(brtree.*) 2s 256M 10 传统 藏宝图(treas. ...
- 8.22 NOIP 模拟题
8.22 NOIP 模拟题 编译命令 g++ -o * *.cpp gcc -o * *.c fpc *.pas 编译器版本 g++/gcc fpc 评测环境 位 Linux, .3GHZ CPU ...
- NOIP模拟 1
NOIP模拟1,到现在时间已经比较长了.. 那天是6.14,今天7.18了 //然鹅我看着最前边缺失的模拟1,还是终于忍不住把它补上,为了保持顺序2345重新发布了一遍.. # 用 户 名 ...
随机推荐
- oracle 数据库连接
前言 关于oracle 数据库如何连接,我一开始以为和mysql 和 sql server一样,写好连接语句然后调用相应的dll. 知道我遇到了两个错误: 1.64位程序不能去驱动32位客户端 2.O ...
- 安装 php_mongodb.dll的坑
背景 php_mongodb.dll在这里介绍的是for php,php_mongodb.dll是这个坑,因为php_mongodb.dll前生是php_mongo.dll,而这个东西,它又不更新了, ...
- 实训篇-Html-计算器
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Java面试题:请谈谈对ThreadLocal的理解?
ThreadLocal是一种特殊的变量存储机制,它提供了一种方式,可以在每个线程中保存数据,而不会受到其他线程的影响.这种机制在多线程编程中非常有用,因为它允许每个线程拥有自己的数据副本,从而避免了数 ...
- 连续三年入围 Gartner 容器竞争格局,阿里云容器服务新布局首次公开
简介: 阿里云连续三年国内唯一入围Gartner容器竞争格局,解读业界'顶流'的产品布局. 近日,国际知名信息技术咨询机构Gartner发布2021年容器竞争格局报告,阿里云成为国内唯一连续三年入选的 ...
- 阿里巴巴云原生 etcd 服务集群管控优化实践
简介: 这些年,阿里云原生 etcd 服务发生了翻天覆地的变化,这篇文章主要分享一下 etcd 服务在面对业务量大规模增长下遇到的问题以及我们是如何解决的,希望对读者了解 etcd 的使用和管控运维提 ...
- AI运动:阿里体育端智能最佳实践
简介: 过去一年,阿里体育技术团队在端智能方面不断探索,特别在运动健康场景下实现了实践落地和业务赋能,这就是AI运动项目.AI运动项目践行运动数字化的理念,为运动人口的上翻提供了重要支撑,迈出了阿里体 ...
- Cube 技术解读 | 支付宝新一代动态化技术架构与选型综述
简介: 支付宝客户端的动态化技术经历三个阶段:现阶段也就是第三阶段是实体组件+部分光栅化的hybrid模式,Cube 就是该模式下的产物. 如标题所述,笔者将持续更新<Cube 技术解读& ...
- DE10-Lite锁相环使用教程
DE10-Lite锁相环使用教程 目标:本文讲述如何在Quartus里设置和例化一个锁相环. 引言 锁相环(PLL)是一种闭环频率控制电路,用于比较压控振荡器的输入信号和输出信号之间的相位差. 负反馈 ...
- 免费的visual studio智能代码插件——CodeGeeX
CodeGeeX是什么?什么是CodeGeeX? CodeGeeX是一款基于大模型的智能编程助手,它可以实现代码的生成与补全,自动为代码添加注释,不同编程语言的代码间实现互译,针对技术和代码问题的智能 ...