csp-c模拟测试43「A·B·C」
B
题解
$f[i][(gcd(prime[j]*prime[k]\%P,P))]=\sum\limits_{k=1}^{k<=num} f[i-1][k]*phi(\frac{P}{prime[j]})$
关于$phi(\frac{P}{prime[j]})$理解
$phi(\frac{P}{prime[j]})$是求$prime[j]$代表的数的个数
$P=k_0*prime[j]$
$x_1=k_1*prime[j]$
$x_2=k_2*prime[j]$
.......
要求代表$prime[j]$数个数就是求$k_1$,$k_2$个数$(k_0,k_1,k_2等互质)$(不互质$gcd就是别的数了$)
移项显然与$k_0$互质数个数就是$phi(\frac{P}{prime[j]})$
代码
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define A 55
const ll mod=1e9+7;
ll f[A][23333],phi[A*A],prm[A*A],to[A*A][A*A];
ll n,m,P;
ll meng(ll x,ll k){
ll ans=1;
for(;k;k>>=1,x=x*x%mod)
if(k&1)
ans=ans*x%mod;
return ans;
}
ll gcd(ll x,ll y){
if(y==0) return x;
return gcd(y,x%y);
}
ll p(ll x){
ll ans=x;
for(ll i=2;i*i<=x;i++){
if(x%i==0){
ans=ans/i*(i-1);
while(x%i==0) x/=i;
}
}
if(x>1) ans=ans/x*(x-1);
return ans;
}
void fen(ll x){
for(ll i=1;i*i<=x;i++){
if(x%i==0){
prm[++prm[0]]=i;
if(i*i!=x) prm[++prm[0]]=x/i;
}
}
sort(prm+1,prm+prm[0]+1);
}
void pre_work(){
fen(P);
for(ll i=1;i<=prm[0];i++)
phi[i]=p(P/prm[i]);
for(ll j=1;j<=prm[0];j++){
for(ll pre=1;pre<=prm[0];pre++){
ll g=gcd(prm[j]*prm[pre]%P,P);
to[j][pre]=lower_bound(prm+1,prm+prm[0]+1,g)-prm;
}
}
}
void work(){
for(ll i=2;i<=n;i++)
for(ll j=1;j<=prm[0];j++)
for(ll pre=1;pre<=prm[0];pre++)
(f[i][to[j][pre]]+=f[i-1][pre]*phi[j]%mod)%=mod;
}
void sub_task(){
pre_work();
for(ll j=1;j<=prm[0];j++)
f[1][j]=phi[j];
work();
for(ll i=1,a;i<=m;i++){
scanf("%lld",&a);
a=lower_bound(prm+1,prm+prm[0]+1,gcd(a,P))-prm;
printf("%lld ",f[n][a]*meng(phi[a],mod-2)%mod)%mod;
}
printf("\n");
}
int main(){
scanf("%lld%lld%lld",&n,&m,&P);
sub_task();
return 0;
}
C
题解
三分,对于怎么看出来三分,这可能是个套路,你觉得这个题你用贪心做不了(但非常像贪心),二分答案会被hack,然后你$dp$也难以做,你三分就可以了
三分$check$贪心做,很水,瞎jb差分一下,我会说贪心我考试时就写对了吗?
注意细节,细节很多,不要死于细节
代码
/*
n*log^2
*/
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define A 222222
struct node{
ll l,r;
friend bool operator < (const node & a,const node &b){
return a.l==b.l?a.r>b.r:a.l<b.l;
}
}wat[A];
ll n,m,t,ans=0x7fffffffffffff,maxx=0,cnt=0;
ll p[A],lef[A],now[A],c[A];
ll check(ll x){
ll sum=0;
for(ll i=1;i<=n;i++){
now[i]=max(p[i]-x,0ll);
c[i]=0;
}
for(ll i=1;i<=n;i++){
ll nowid=lef[i];
c[i]+=c[i-1];
if(lef[i]==0) continue ;
ll cha=c[i];
// printf("i=%lld c[i]=%lld c[i-1]=%lld\n",i,c[i],c[i-1]);
// printf("i=%lld now+cha=%lld\n",i,now[i]+cha);
if(now[i]+cha>0){
sum+=now[i]+cha;
c[i]-=(now[i]+cha);
c[wat[nowid].r+1]+=now[i]+cha;
now[i]=0;
}
}
for(ll i=1;i<=n;i++){
ll cha=c[i];
// printf("now=%lld x=%lld cha=%lld\n",now[i],x,cha);
if(now[i]+cha>0) return 0x7fffffffff;
}
return sum+x*t;
}
int main(){
// freopen("da.in","r",stdin);
// freopen("ans.bf","w",stdout);
scanf("%lld%lld%lld",&n,&m,&t);
for(ll i=1;i<=n;i++){
scanf("%lld",&p[i]);
maxx=max(maxx,p[i]);
}
for(ll i=1;i<=m;i++){
scanf("%lld%lld",&wat[i].l,&wat[i].r);
}
sort(wat+1,wat+m+1);
for(ll i=1;i<=m;i++){
if(!lef[wat[i].l])
lef[wat[i].l]=i;
}
for(ll i=1;i<=n;i++)
if(wat[lef[i-1]].r>=i){
if(wat[lef[i-1]].r>wat[lef[i]].r)
lef[i]=lef[i-1];
}
ll l=0,r=maxx;
while(l<r){
ll len=(r-l);
ll lmid=l+len/3,rmid=r-len/3; ll lnow=check(lmid),rnow=check(rmid);
// printf("l=%lld r=%lld\n",l,r);
if(lnow>=rnow) l=lmid+1;
else r=rmid-1;
ans=min(ans,lnow);
ans=min(ans,rnow);
}
// printf("%lld\n",check(5));
printf("%lld\n",ans);
}
csp-c模拟测试43「A·B·C」的更多相关文章
- NOIP模拟测试19「count·dinner·chess」
反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...
- csp-s模拟测试44「D·E·F」
用心出题,用脚造数据 乱搞场 1 #include<bits/stdc++.h> 2 #define re register 3 #define int long long 4 #defi ...
- NOIP模拟测试30「return·one·magic」
magic 题解 首先原式指数肯定会爆$long$ $long$ 首先根据欧拉定理我们可以将原式换成$N^{\sum\limits_{i=1}^{i<=N} [gcd(i,N)==1] C_{G ...
- csp-s模拟测试42「世界线·时间机器·密码」
$t3$不会 世界线 题解 题目让求的就是每个点能到点的数量$-$出度 设每个点能到的点为$f[x]$ 则$f[x]=x \sum\limits_{y}^{y\in son[x]} U f[y]$ 用 ...
- NOIP模拟测试38「金·斯诺·赤」
金 辗转相减见祖宗 高精 #include<bits/stdc++.h> using namespace std; #define A 2000 #define P 1 #define N ...
- NOIP模拟测试28「阴阳·虎·山洞」
写这几个题解我觉得我就像在按照官方题解抄一样 阴阳 题解 将题目中给的阴阳看作黑色和白色 首先我们观察到最后生成图中某种颜色必须是竖着单调递增或竖着单调递减 类似这样 否则不满足这个条件 但合法染色方 ...
- NOIP模拟测试20「周·任·飞」
liu_runda出的题再次$\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%\%$ 任 题解 题目中为什么反复强调简单路径,没有环 没有环的图中点数-边数=联通块数 前缀和维护边 ...
- NOIP模拟测试23「mine·water·gcd」
mine 题解 一道比较水的dp 考试因为初始化挂掉了只有$80$分 代码有注释 #include<bits/stdc++.h> using namespace std; //无脑dp # ...
- NOIP模拟测试16「Drink·blue·weed」
话说这次考试 Drink 非常棒的一道卡常练习题,适合练习卡常 真的很棒 前置卡常知识 1.char要比int快 char是最快的 输出putchar,输入getchar 在这个题快了7000豪 2. ...
随机推荐
- vscode 超好用的前端插件
一 vscode 前端调试接口的插件 作为前端工程师,接口的调试是我们必不可少的工作.以前用过postman,但是作为一个vscode重度使用者,我希望看看vscode能否进行对接口的调试.省的跟后台 ...
- K8s Scheduler 在调度 pod 过程中遗漏部分节点的问题排查
问题现象 在TKE控制台上新建版本为v1.18.4(详细版本号 < v1.18.4-tke.5)的独立集群,其中,集群的节点信息如下: 有3个master node和1个worker node, ...
- IOS小组件(6):小组件实现时钟按秒刷新
引言 上一节中我们了解了IOS小组件的刷新机制,发现根本没法实现按秒刷新,但是看别的App里面有做到,以为用了什么黑科技,原来是因为系统提供了一个额外的机制实现时间的动态更新,不用走小组件的刷新机 ...
- 分布式存储ceph---openstack对接ceph存储后端(4)
ceph对接openstack环境 一.使用RBD方式提供存储,如下数据: 1.image:保存glance中的image 2.volume存储:保存cinder的volume:保存创建虚拟机时选择创 ...
- OpenStack neutron vlan 模式下的网络包流向
时间:2015-01-15 18:09:41 1.什么是Neutron? Neutron是OpenStack的network project ,是NaaS(networking-as-a-servic ...
- linux python3安装whl包时报错解决:is not a supported wheel on this platform
原因1 你下载安装的包不是当前平台所支持的 原因2 你下载的包,不符合你所在的平台的安装whl的名称规范,所以出错.比如当前我要安装的包是:pymssql-2.1.5-cp36-cp36m-manyl ...
- 7.6 passwd:修改用户密码
7.6 passwd:修改用户密码 passwd命令可以修改用户密码及密码过期时间等内容,是工作中很常用的命令.普通用户和超级用户都可以运行passwd命令,但普通用户只能更改自身的用户密码, ...
- 【错误解决】The prefix "context" for element "context:component-scan" is not bound
在配置spring相关的applicationContext.xml文件时报以上错误 原因是缺失context的namespace. http://www.springframework.org/sc ...
- Django(43)restful接口规范
restful接口规范 什么是接口规范?接口规范就是为了采用不同的后台语言,也能使用同样的接口获取到同样的数据.如何写接口:接口规范是规范化书写接口的,写接口要写url.响应数据 注:如果将 ...
- 『动善时』JMeter基础 — 34、JMeter接口关联【XPath提取器】
目录 1.XPath提取器介绍 2.XPath提取器界面详解 3.XPath提取器的使用 (1)测试计划内包含的元件 (2)网易首页请求界面内容 (3)XPath提取器界面内容 (4)百度首页请求界面 ...