CSP提高组模拟1

news/2024/9/21 4:39:58/文章来源:https://www.cnblogs.com/zhengchenxi/p/18299403

T1

很明显的最短路floyed算法,但是这个最大的点权却不是很好维护,但我们可以想到枚举最大的点权其实就可以相当于枚举floyed中的k,那么这时我们要对k进行一个排序操作,使得我们每次枚举的中转点k为枚举经过路径的点权最大的点从而达到同时走最短路并维护点权最大值。

点击查看代码
#include<bits/stdc++.h>
using namespace std;#define int long long
const int N=400;
int n,m,q;struct lmy
{int id,w;
}pos[N];
int rk[N];
int dis[N][N],ans[N][N];bool comp(lmy a,lmy b)
{return a.w<b.w;
}
signed main()
{
//	freopen("path.in","r",stdin);
//	freopen("path.out","w",stdout); scanf("%lld%lld%lld",&n,&m,&q);for(int i=1;i<=n;i++){scanf("%lld",&pos[i].w);pos[i].id=i;}sort(pos+1,pos+1+n,comp);for(int i=1;i<=n;i++){rk[pos[i].id]=i;}memset(dis,0x3f,sizeof dis);for(int i=1;i<=n;i++){dis[i][i]=0;}for(int i=1;i<=m;i++){int x,y,dt;scanf("%lld%lld%lld",&x,&y,&dt);dis[rk[x]][rk[y]]=min(dis[rk[x]][rk[y]],dt);dis[rk[y]][rk[x]]=min(dis[rk[y]][rk[x]],dt);}memset(ans,0x3f,sizeof ans);for(int k=1;k<=n;k++){for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(i==j) continue;dis[i][j]=min(dis[i][j],dis[i][k]+dis[k][j]);if(dis[i][j]==dis[i][k]+dis[k][j]) ans[i][j]=min(ans[i][j],dis[i][j]+max({pos[i].w,pos[j].w,pos[k].w}));}}}for(int i=1;i<=q;i++){int s,t;scanf("%lld%lld",&s,&t);if(ans[rk[s]][rk[t]]>=0x3f3f3f3f3f3f3f3f) printf("-1\n");else printf("%lld\n",ans[rk[s]][rk[t]]);}
}
##T2

首先就是可以想到维护一个二维前缀和。
然后像这种具有单调性的数列(只维护正整数的前缀和)维护我们可以想到用单调队列。
那我们就可以一行一行的删去看是否符合条件,
最后剩下的我们就一点一点凑。

点击查看代码
#include<bits/stdc++.h>
using namespace std;#define int long long
const int N=2010;
int n,k;
int s[N][N],g[N][N];
int up[N][N];
int sta[N],tp;
int l[N],r[N];
int ax,ay,bx,by;
int get(int a,int b,int c,int d)
{return s[c][d]+s[a-1][b-1]-s[a-1][d]-s[c][b-1];
}
signed main()
{
//	freopen("matrix.in","r",stdin);
//	freopen("matrix.out","w",stdout);scanf("%lld%lld",&k,&n);for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){scanf("%lld",&g[i][j]);if(g[i][j]>=k&&g[i][j]<=2*k){printf("%lld %lld %lld %lld",j,i,j,i);exit(0);}s[i][j]=s[i][j-1]+g[i][j];}}for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){s[i][j]=s[i-1][j]+s[i][j];if(s[i][j]>=k&&s[i][j]<=2*k){printf("1 1 %lld %lld",j,i);exit(0);}}}int mx=0;for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(g[i][j]<k){up[i][j]=up[i-1][j]+1;}}sta[tp=1]=0;up[i][0]=-1;for(int j=1;j<=n;j++){while(tp&&up[i][sta[tp]]>=up[i][j]) tp--;l[j]=sta[tp]+1;sta[++tp]=j;}sta[tp=1]=n+1;up[i][n+1]=-1;for(int j=n;j>=1;j--){while(tp&&up[i][sta[tp]]>=up[i][j]) tp--;r[j]=sta[tp]-1;sta[++tp]=j;if(up[i][j]){int now=get(i-up[i][j]+1,l[j],i,r[j]);if(now>=k&&now<=2*k){printf("%lld %lld %lld %lld",l[j],i-up[i][j]+1,r[j],i);exit(0);}if(now>mx){mx=now;ax=i-up[i][j]+1;ay=l[i];bx=i;by=r[j];}}}}if(mx<k) {printf("NTE");exit(0);}for(int i=bx;i>=ax;i--){int now=get(i,ay,i,by);if(now>=k&&now<=2*k){printf("%lld %lld %lld %lld",ay,i,by,i);exit(0);} if(now>2*k){mx=now;for(int j=by;j>=ay;j--){mx-=g[i][j];if(mx>=k&&mx<=k*2){printf("%lld %lld %lld %lld",ay,i,j-1,i);exit(0);}}}else{mx-=now;if(mx>=k&&mx<=2*k){printf("%lld %lld %lld %lld",ay,ax,by,i-1);exit(0);}}}
}

T3

区间修改和查询很容易的想到了线段树,但赛时没打出来。
先来看下欧拉函数的定义:

那注意一下300这个数字,1到300之间有62个质数,刚好在long long范围内,我们可以考虑用状态压缩来维护这个有关质数的问题,同时我们把欧拉函数分成两部分分开来处理,先预处理出来这62个质数的(p-1)/p,那我们线段树就只需要维护区间每个数的质数情况和乘积。

点击查看代码
#include<bits/stdc++.h>
using namespace std;#define int long long 
const int mod=1e9+7;
const int N=1e6;
int cnt=62,pr[70]={2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293};
int n,m;
int a[N],inv[N],tp[N];int qpow(int a,int b)
{int ans=1;while(b){if(b&1){ans=ans*a%mod;}a=a*a%mod;b=b>>1;}return ans;
}
#define lson (rt<<1)
#define rson (rt<<1|1)struct lmy
{int l,r;int pd,lz,fc,lf;lmy(){pd=lz=1;fc=lf=0; }
}tr[N<<2];void pushup(int rt)
{tr[rt].pd=tr[lson].pd*tr[rson].pd%mod;tr[rt].fc=tr[lson].fc|tr[rson].fc;
}
void pushdown(int rt)
{tr[lson].pd=tr[lson].pd*qpow(tr[rt].lz,tr[lson].r-tr[lson].l+1)%mod;tr[rson].pd=tr[rson].pd*qpow(tr[rt].lz,tr[rson].r-tr[rson].l+1)%mod;tr[lson].lz=tr[lson].lz*tr[rt].lz%mod;tr[rson].lz=tr[rson].lz*tr[rt].lz%mod;tr[rt].lz=1;tr[lson].fc|=tr[rt].lf;tr[rson].fc|=tr[rt].lf;tr[lson].lf|=tr[rt].lf;tr[rson].lf|=tr[rt].lf;tr[rt].lf=0;
}
void build(int rt,int l,int r)
{tr[rt].l=l;tr[rt].r=r;if(l==r){tr[rt].pd=a[l];for(int i=0;i<cnt;i++){if(a[l]%pr[i]==0) tr[rt].fc|=((1ll)<<i);}tr[rt].lz=1;return ;}int mid=(l+r)>>1;build(lson,l,mid);build(rson,mid+1,r);pushup(rt);
}
void update(int rt,int l,int r,int c,int f)
{if(l<=tr[rt].l&&r>=tr[rt].r){tr[rt].pd=tr[rt].pd*qpow(c,tr[rt].r-tr[rt].l+1)%mod;tr[rt].lz=tr[rt].lz*c%mod;tr[rt].fc|=f;tr[rt].lf|=f;return ;}pushdown(rt);int mid=(tr[rt].l+tr[rt].r)>>1;if(l<=mid) update(lson,l,r,c,f);if(r>mid) update(rson,l,r,c,f);pushup(rt);
}
int query_pd(int rt,int l,int r)
{if(l<=tr[rt].l&&tr[rt].r<=r){return tr[rt].pd;}int ans=1;pushdown(rt);int mid=(tr[rt].l+tr[rt].r)>>1;if(l<=mid) ans=ans*query_pd(lson,l,r)%mod;if(r>mid) ans=ans*query_pd(rson,l,r)%mod;return ans;
}
int query_fc(int rt,int l,int r)
{if(l<=tr[rt].l&&tr[rt].r<=r){return tr[rt].fc;}int ans=0;pushdown(rt);int mid=(tr[rt].l+tr[rt].r)>>1;if(l<=mid) ans|=query_fc(lson,l,r);if(r>mid) ans|=query_fc(rson,l,r);return ans;
}
void init()
{for(int i=2;i<=300;i++){inv[i]=qpow(i,mod-2);}for(int i=0;i<=cnt-1;i++){tp[i]=inv[pr[i]]*(pr[i]-1)%mod;}
} 
signed main()
{freopen("array.in","r",stdin);freopen("array.out","w",stdout);init();scanf("%lld%lld",&n,&m);for(int i=1;i<=n;i++) scanf("%lld",&a[i]);build(1,1,n);for(int i=1;i<=m;i++){char op[20];scanf("%s",op);int l,r;scanf("%lld%lld",&l,&r);if(op[0]=='1'){int z;scanf("%lld",&z);int f=0;for(int j=0;j<cnt;j++){if(z%pr[j]==0) f|=((1ll)<<j);}update(1,l,r,z,f);}else{int x=query_pd(1,l,r);int y=query_fc(1,l,r);int ans=x;
//			cout<<ans<<" ";for(int j=0;j<cnt;j++){if((y>>j)&1) ans=ans*tp[j]%mod;}printf("%lld\n",ans);}}
}
#T4 先鸽着

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

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

相关文章

【服务器搭建】为啥虚拟主机不能用IP直接访问?

需求 直接用IP访问了自己在线上的网站,结果发现被拒绝❓因为,IP映射的是一整台服务器,而服务器上可以部署的的服务是多种多样的。除了web网站服务,还可能有ftp文件传输服务,mail邮箱服务等。这时仅仅给出IP是不够的,需要在IP后添加端口号作进一步区分。 当然,如果用浏览…

应急响应命令(Linux)

netstat -anultp 查看进程(用来判断开启了哪些服务等)ls -al 查看目录下所有文件,包括隐藏文件 ls -alt 查看目录下所有文件,包括隐藏文件,按时间顺序排序cat access.log | wc -l 查看文件的行数 wc -l是查看文件行数的意思cat -e access.log | grep 1.php 查…

U7-11课综合练习+12课阶段测评练习——复习练习题目

[2的n次方] 高精度乘法复习资料:https://www.cnblogs.com/jayxuan/p/18287673重复做以下操作 $n $ 次:对每一位乘以 $2 $,然后进位。(当然也可以使用正常的高精度乘法)【参考代码】 #include<bits/stdc++.h> using namespace std;int ans[59]; int main() {int n;ci…

telegram发卡机器人

iDataRiver是一家提供telegram发卡机器人的发卡平台,商家上架商品后,自动获得平台提供的免费telegram发卡机器人。iDataRiver是一家提供telegram发卡机器人的发卡平台。 商家上架商品后,自动获得平台提供的免费telegram发卡机器人。 如果希望将机器人头像/名称设置成自己的,…

发卡网收益如何usdt提现

iDataRiver是一家支持直接使用加密货币USDT提现的发卡平台, 支持TRON(波场)、BSC(币安)、ETH(以太坊)区块链。iDataRiver是一家支持直接使用加密货币USDT提现的发卡平台, 支持TRON(波场)、BSC(币安)、ETH(以太坊)区块链。 由于iDataRiver天然的web3属性,加密货币拥有第一原生地…

《JavaScript权威指南第7版》中文PDF+英文PDF+源代码 +JavaScript权威指南(第6版)(附源码)PDF下载阅读分享推荐

JavaScript是Web编程语言。绝大多数网站都使用JavaScript,所有现代Web浏览器(无论是桌面、平板还是手机浏览器,书中以后统称为浏览器)都包含JavaScript解释器,这让JavaScript成为有史以来部署最广泛的编程语言。过去十年,Node.js让浏览器之外的JavaScript编程成为可能,N…

封装 uniapp 请求库的最佳实践

背景 在前端开发中,HTTP 请求是与服务器进行数据交互的核心手段。无论是获取数据还是提交数据,前端应用几乎都离不开 HTTP 请求。在 uniapp 中,uni.request 是官方提供的用于发起 HTTP 请求的基础 API。然而,直接使用 uni.request 存在一些问题和不足,比如:代码冗余:每次…

FastStone Capture (屏幕截图) v9.2 汉化版

下载地址:https://www.mediafire.com/file/b6crzq480nyzf8v/FSCapture-9.2-CN.zip/file 软件简介: FastStone Capture 是一款出色的屏幕截图(捕捉)软件,它集图像捕捉、浏览、编辑、视频录制等功能于一身,功能完善、使用方便,值得推荐! 软件提供多种截图方式(如:活动窗…

9、IDEA集成Github

9.1、登录Github账号 9.1.1、打开IDEA的Settings界面如上图所示,打开IDEA的 Settings(设置)界面。 9.1.2、使用账号密码登录(方式一)如上图所示,在“Version Control”->“Github”中,点击“+”按钮,在登录弹窗中,输入GitHub的账号密码直接登录。注意:该方式可能由…

黑球白球巧妙异或问题

题目:一个桶里一共有a个白球和b个黑球。每次拿出2个球,并且每个球被拿出的概率相等。如果拿出一黑一白,就往桶里放进一个黑球;如果拿出两个黑或者两个白,就往桶里放进一个白球。求:最后只剩一个黑球的概率是多少?答案:如果黑球个数是偶数,最后剩下为黑球的概率是0%;如…

动态条件实现java

提交页面设计 json数据格式[{"name": "规则1","action": {"with": [{"type": "SHOW","targets": ["xd_hh_158444776217"]},{"type": "HIDE","targets": [&qu…

玩一玩yolov5 自己训练模型识别马克杯

python 虚拟环境搭建 conda create -n yolo python==3.8yolov5下载 git clone https://github.com/ultralytics/yolov5 cd yolov5 activate yolo pip install -r requirements.txt准备数据集 官方介绍:https://github.com/ultralytics/yolov5/wiki/Train-Custom-Data 建立文件…