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;
}
View Code

 

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);
}    
View Code

 

转载于:https://www.cnblogs.com/znsbc-13/p/11524078.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/349561.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小甲鱼python全部视频_小甲鱼全套教程之Python系列视频教程

Python 当前位置&#xff1a;主页 > 编程教程 > Python > 小甲鱼全套教程之Python系列视频教程 小甲鱼全套教程之Python系列视频教程 教程大小&#xff1a; 发布时间&#xff1a;2015-04-18   下载次数&#xff1a;次 本套小甲鱼全套教程之Python系列视频教程是比较…

如何有效开展小组教学_高效课堂 有效教学 | 教育部专家到徐州市第三中学开展教研活动...

原标题&#xff1a;高效课堂 有效教学 | 教育部专家到徐州市第三中学开展教研活动前言2020年12月1日&#xff0c;教育部基础教育课程教材发展中心徐州调研暨徐州市2020年高中语文教师“深度学习”研讨活动、徐州市2020年高中化学骨干教师“三新”培训在徐州市第三中学举办。参加…

技术管理角色认知-管理都需要做哪些事

背景 即管理的具体形式&#xff0c;关于what的问题&#xff1f;管理到底要做哪些事情&#xff1f; 派别定义说明过程管理是5个要素组成的一种普遍的人类活动&#xff0c;这5个要素是&#xff1a;计划&#xff0c;组织&#xff0c;指挥&#xff0c;协调&#xff0c;控制亨利法约…

带哨兵节点的链_HBA公链 | IPFS:区块链“不可能三角”的可能解

你知道区块链中的“不可能三角”吗&#xff1f;即区块链无法同时达到可扩展性&#xff08;Scalability&#xff09;、去中心化&#xff08;Decentralization&#xff09;和安全&#xff08;Security&#xff09;。这三个要素中只能同时兼顾两个&#xff0c;比如&#xff0c;要想…

python实现微信小程序的接口自动化_appium+python自动化56-微信小程序自动化(摩拜为例)...

前言 最近微信的小程序越来越多了&#xff0c;随之带来的问题是&#xff1a;小程序如何做自动化测试&#xff1f; 本篇以摩拜小程序为例&#xff0c;介绍如何定位小程序里面的元素 运行环境&#xff1a; android 7.0 appium v1.7.1 webview进程 1.小程序和微信公众号还不太一样…

swingworker_使用SwingWorker的Java Swing中的多线程

swingworker如果要使用Swing用J​​ava编写桌面或Java Web Start程序&#xff0c;您可能会觉得需要通过创建自己的线程在后台运行某些程序。 没有什么可以阻止您在Swing中使用标准的多线程技术&#xff0c;并且需要遵循通常的注意事项。 如果有多个线程访问相同的变量&#xf…

指定端口传输_一段话告诉你什么是端口

1、端口的含义端口是指接口电路中的一些寄存器&#xff0c;这些寄存器分别用来存放数据信息、控制信息和状态信息&#xff0c;相应的端口分别称为数据端口、控制端口和状态端口。电脑运行的系统程序&#xff0c;其实就像一个闭合的圆圈&#xff0c;但是电脑是为人服务的&#x…

loop在python中什么意思_python中迭代什么意思

1、迭代&#xff1a; 迭代是通过重复执行的代码处理相似的数据集的过程&#xff0c;并且本次迭代的处理数据要依赖上一次的结果继续往下做&#xff0c;上一次产生的结果为下一次产生结果的初始状态&#xff0c;如果中途有任何停顿&#xff0c;都不能算是迭代。例如&#xff1a;…

使用Spring Data的Apache Ignite

Spring Data提供了一种统一而简单的方法来访问不同类型的持久性存储&#xff0c;关系数据库系统和NoSQL数据存储。 它位于JPA之上&#xff0c;添加了另一层抽象并定义了基于标准的设计以在Spring上下文中支持持久层。 Apache Ignite IgniteRepository实现了Spring Data CrudR…

js hover图片放大不遮挡_CSS3+JS 实现放大镜

注意&#xff1a;看懂本文需要&#xff1a;懂中文 &#xff1a;)学习过 JavaScript 和 css代码较长&#xff0c;框框可左右滑动哦您的观看和点赞是对本公众号最大力的支持 ~~原文链接&#xff1a;https://blog.csdn.net/qq_43624878/article/details/110197749 CSS3JS完美实现放…

python装饰器class_Python中的各种装饰器详解

Python装饰器&#xff0c;分两部分&#xff0c;一是装饰器本身的定义&#xff0c;一是被装饰器对象的定义。 一、函数式装饰器&#xff1a;装饰器本身是一个函数。 1.装饰函数&#xff1a;被装饰对象是一个函数 [1]装饰器无参数&#xff1a; a.被装饰对象无参数&#xff1a; &g…

odoo controller 继承

方式一&#xff1a; 继承基类&#xff0c;直接重写方法 from odoo.addons.web.controllers.main import Exportclass PsExport(Export): http.route(/web/export/get_fields, typejson, auth"user") def get_fields(self, model, prefix, parent_name , import_co…

python字符串startswith_Python 字符串 startswith() 使用方法及示例

Python 字符串 startswith() 使用方法及示例如果字符串以指定的前缀(字符串)开头&#xff0c;则startswith()方法将返回True。如果不是&#xff0c;则返回False。startswith()的语法为&#xff1a;str.startswith(prefix[, start[, end]])startswith()参数startswith()方法最多…

odoo连接外部数据库

odoo框架默认的访问时Postgres数据库&#xff0c;但在实际的应用场景中&#xff0c;不可避免的使用到其他数据库&#xff0c;所以有必要研究如何连接其他第三方数据库&#xff0c;这里分享下OCA的相关模块&#xff0c;具体的源代码在这里。 我将第三方的数据库需要连接的情况汇…

整型和bcd的对应关系_微信与多闪之争背后,好友关系链到底是如何窃取的?

这几天从发布到全面推广&#xff0c;多闪已经快速的超越100万用户&#xff0c;迅速占领了appsotre榜首&#xff0c;在七麦数据中也是蝉联第一。但因多闪包括头条产品登录采取都支持【微信第三方登录】。很多用户都反馈是否自己的关系链被多闪、甚至是抖音窃取&#xff0c;并且腾…

线程同步,线程不同步_同步多线程集成测试

线程同步,线程不同步测试线程非常困难&#xff0c;这使得为被测多线程系统编写良好的集成测试非常困难。 这是因为在JUnit中&#xff0c;测试代码&#xff0c;被测对象和任何线程之间没有内置的同步。 这意味着&#xff0c;当您必须为创建并运行线程的方法编写测试时&#xff0…

ehcache 默认大小_简单的使用ehcache

ehcache是一个用Java实现的使用简单&#xff0c;高速&#xff0c;实现线程安全的缓存管理类库&#xff0c;ehcache提供了用内存&#xff0c;磁盘文件存储&#xff0c;以及分布式存储方式等多种灵活的cache管理方案。同时ehcache作为开放源代码项目&#xff0c;采用限制比较宽松…

JS定时器使用,定时定点,固定时刻,循环执行

本文概述&#xff1a;本文主要介绍通过JS实现定时定点执行&#xff0c;在某一个固定时刻执行某个函数的方法。比如说在下一个整点执行&#xff0c;在每一个整点执行&#xff0c;每隔10分钟定时执行的方法。 JavaScript中有两个定时器方法&#xff1a;setTimeout&#xff08;&am…

axios 跨域_当遇到跨域开发时,我们如何处理好前后端配置和请求库封装

我们知道很多大型项目都或多或少的采用跨域的模式开发, 以达到服务和资源的解耦和高效利用. 在大前端盛行的今天更为如此, 前端工程师可以通过nodejs或者Nginx轻松搭建起web服务器.这个时候我们只需要请求后端服务器的接口即可实现系统的业务功能开发.这个过程中会涉及到web页面…

Java数据类型和标识符

在本教程中&#xff0c;我们将了解Java中的数据类型和标识符。 Java语言具有丰富的数据类型实现。 数据类型指定大小和可以存储在标识符中的值的类型。 Java数据类型分为两类&#xff1a; 原始数据类型 非原始数据类型 原始类型 Java定义了八种原始数据类型&#xff1a;字…