Codeforces Round #536 (Div. 2)
前言
如您所见这又是一篇咕了的文章,直接咕了10天
好久没打CF了 所以还是个蓝名菜鸡
机房所有人都紫名及以上了,wtcl
这次前4题这么水虽然不知道为什么花了1h,结果不知道为什么搞到一半出锅了,后面直接unrated了qwq
虽然如果是rated我就掉成newbie了
A
题意
在一个矩阵中统计\(a_{i,j}=a_{i-1,j-1}=a_{i-1,j+1}=a_{i+1,j-1}=a_{i+1,j+1}='X'\)
题解
sbt
B
题意
有n种菜,每种菜有价格和数量,然后依次会来m个客人,依次服务每个客人,每个客人需要一定数量的某个菜,如果有就给他,如果他要的菜没有就每次给他最便宜的中编号最小的菜,如果没有菜他就吃菜不付钱.问每个人交多少钱
题解
用set维护菜,价格第一关键字,编号第二关键字,然后模拟
C
题意
n个数(n为偶数),要分组,每组不少于两个数,每组价值为元素和的平方,求最小价值和
题解
显然两个数一组,同时显然排完序后每次从两边各拿一个数凑成一组
D
题意
给一个图,从1号点出发遍历这个图(随便遍历),第一次走到某个点就把编号加入一个序列,问最小字典序序列
题解
不知道比NOIPD2T1水到哪去了
显然要从能走到的没走过的点里选一个编号最小的走,用堆维护即可
E
题意
有k个红包,每个可以在\([l_i,r_i]\)时间里取到,如果取这个红包就得到一定收益,同时往后走直到\(d_i+1\)时刻才能继续取红包\((l_i\le r_i\le d_i)\)
现在贪心取红包,如果在某个时刻能取红包,那么就取价值最大中d最大的红包
现在可以骚扰m次,在时刻x骚扰会导致x时刻无法取红包,问最少取多少收益
题解
这题就是个dp啊,为什么我不去做呢qwq
首先因为\(r_i\le d_i\),所以每个时间点取红包都是唯一的,不会相互影响.用set预处理出每个时间点取那个红包.可以发现每个红包可以看成一个\([i,d_i]\)有收益的线段,然后可以插入m个长度为1收益为0线段,然后依次填满时间段,问最小代价.设\(f[i][j]\)表示做到时刻i,骚扰j次,转移枚举下一位骚扰或不骚扰即可
然而我做的时候各种细节没考虑,交了1h
#include<bits/stdc++.h>
#define LL long long
#define db double
#define il inline
#define re register
using namespace std;
const int N=1e5+10;
il int rd()
{
int x=0,w=1;char ch=0;
while(ch<'0'||ch>'9') {if(ch=='-') w=-1;ch=getchar();}
while(ch>='0'&&ch<='9') {x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*w;
}
struct node
{
int l,r,d,x;
bool operator < (const node &bb) const {return x!=bb.x?x<bb.x:d<bb.d;}
}a[N<<1];
il bool cmp(node a,node b){return a.l<b.l;}
int n,m,kk;
LL f[N][210],inf=1ll<<50;
priority_queue<node> q;
int main()
{
//wtcl
n=rd(),m=rd(),kk=rd();
for(int i=1;i<=kk;++i) a[i].l=rd(),a[i].r=rd(),a[i].d=rd(),a[i].x=rd();
for(int i=1;i<=n;++i) ++kk,a[kk].l=a[kk].r=a[kk].d=i,a[kk].x=0;
sort(a+1,a+kk+1,cmp);
memset(f,0x3f3f3f,sizeof(f));
f[0][0]=0;
for(int i=1,o=1;i<=n;++i)
{
while(a[o].l==i) q.push(a[o++]);
while(!q.empty()&&q.top().r<i) q.pop();
int d=n+1,x=inf;
if(!q.empty()) d=q.top().d,x=q.top().x;
for(int j=0;j<=m;++j)
{
f[i][j+1]=min(f[i][j+1],f[i-1][j]);
f[d][j]=min(f[d][j],f[i-1][j]+x);
}
}
LL ans=inf;
for(int j=0;j<=m;++j) ans=min(ans,f[n][j]);
cout<<ans<<endl;
return 0;
}
F
题意
一个数列,\(f_1=f_2=...=f_{k-1}=1,f_n=m\),并且\(f_i=\prod_{j=1}^{k}{f_{i-j}}^{b_j}\),问\(f_k\)
题解
首先通过手玩可以发现式子可以转化成\({f_k}^a=f_n=m\),然后这个k是可以矩乘求出的(怎么求自己玩去).注意到模数为998244353,原根为3,可以考虑原根,即设\(f_k=g^x,m=g^y\),原式变为\(g^{ax}=g^y(mod\ 998244353)\),根据欧拉定理,这等价于\(ax=y(mod\ 998244352)\),然后y可以bsgs求,x可以exgcd求
注意欧拉定理,矩乘模数是原模数-1
我这种菜鸡什么板子都写错,pp都pp不了
#include<bits/stdc++.h>
#define LL long long
#define il inline
#define re register
#define db double
using namespace std;
const int N=700+10,mod=998244353,g=3;
il LL rd()
{
LL x=0,w=1;char ch=0;
while(ch<'0'||ch>'9') {if(ch=='-') w=-1;ch=getchar();}
while(ch>='0'&&ch<='9') {x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*w;
}
map<int,int> ha;
il LL fpow(LL a,LL b){LL an=1;while(b){if(b&1) an=1ll*an*a%mod;a=1ll*a*a%mod,b>>=1;}return an;}
il LL bsgs(LL a,LL b)
{
ha.clear();
LL kk=sqrt(mod)+1,aa=b,ka=fpow(a,kk);
for(int i=0;i<kk;++i) ha[aa]=i,aa=aa*a%mod;
aa=1;
for(int i=0;i<=kk;++i)
{
if(ha.find(aa)!=ha.end()&&i*kk-ha[aa]>=0) return i*kk-ha[aa];
aa=aa*ka%mod;
}
return -1;
}
int n,m,kk,b[110];
struct martix
{
int n,m;
int a[110][110];
martix(){}
il void init()
{
for(int i=1;i<=n;i++) a[i][i]=1;
}
martix(int n,int m):n(n),m(m)
{
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
a[i][j]=0;
}
martix operator * (const martix &b) const
{
martix an(n,b.m);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
for(int k=1;k<=b.m;k++)
an.a[i][j]=(an.a[i][j]+1ll*a[i][k]*b.a[k][j]%(mod-1))%(mod-1);
return an;
}
martix operator ^ (const LL &bb) const
{
martix a=*this,an(a.n,a.m);
an.init();
LL b=bb;
while(b)
{
if(b&1) an=an*a;
a=a*a,b>>=1;
}
return an;
}
}ma,mb;
il void exgcd(LL a,LL b,LL &d,LL &x,LL &y)
{
if(!b){d=a,x=1,y=0;return;}
exgcd(b,a%b,d,y,x),y-=a/b*x;
}
int main()
{
n=rd();
for(int i=1;i<=n;++i) b[i]=rd();
kk=rd(),m=rd();
ma.n=ma.m=mb.n=mb.m=n;
ma.a[1][n]=1;
for(int i=1;i<n;++i) mb.a[i+1][i]=1;
for(int i=1;i<=n;++i) mb.a[n-i+1][n]=b[i]%(mod-1);
ma=ma*(mb^(kk-n));
LL bb=bsgs(g,m),x,y,d;
//cout<<ma.a[1][n]<<endl;sgllsjlg
//cout<<bb<<endl;
if(bb==-1) return puts("-1"),0;
exgcd(ma.a[1][n],mod-1,d,x,y);
//cout<<d<<endl;
if(bb%d) return puts("-1"),0;
y=(mod-1)/d;
//cout<<x<<endl;
x=(1ll*(x%y+y)%y*(bb/d)%y+y)%y;
printf("%d\n",(int)fpow(g,x));
return 0;
}
Codeforces Round #536 (Div. 2)的更多相关文章
- Codeforces Round 536 (Div. 2) (E)
layout: post title: Codeforces Round 536 (Div. 2) author: "luowentaoaa" catalog: true tags ...
- Codeforces Round #536 (Div. 2) F 矩阵快速幂 + bsgs(新坑) + exgcd(新坑) + 欧拉降幂
https://codeforces.com/contest/1106/problem/F 题意 数列公式为\(f_i=(f^{b_1}_{i-1}*f^{b_2}_{i-2}*...*f^{b_k} ...
- Codeforces Round #536 (Div. 2) E dp + set
https://codeforces.com/contest/1106/problem/E 题意 一共有k个红包,每个红包在\([s_i,t_i]\)时间可以领取,假如领取了第i个红包,那么在\(d_ ...
- Codeforces Round #536 (Div. 2)--1106D - Lunar New Year and a Wander
https://codeforces.com/contest/1106/problem/D 题意:求出字典序最小的走法 解法:走到每个点,都选取与这个点连通的序号最小的点,并且这个序号最小的点没有被访 ...
- Codeforces Round #536 (Div. 2) B. Lunar New Year and Food Ordering
#include <bits/stdc++.h> #define N 300010 #define PII pair<int, int> using namespace std ...
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
随机推荐
- css的简单学习笔记
1.CSS的简介 *css :层叠样式表 **层叠: 一层一层. **样式表: 具有大量的属性和属性值 *使得页面的显示效果更加好. *css将网页内容和显示样式进行分离,提高了显示功能. *css不 ...
- java equals和hashcode方法
equals()方法比较两个对象的引用是否相同 hashcode()方法比较两个对象的哈希码是否相同
- php xml操作
<?php if(!defined('DEDEINC')) { exit("Request Error!"); } function lib_videotag(&$c ...
- JAVA后端生成Token(令牌),用于校验客户端,防止重复提交
转:https://blog.csdn.net/u011821334/article/details/79390980 转:https://blog.csdn.net/joshua1830/artic ...
- C# Excel转换成Json工具(含源码)
可执行版本下载:https://github.com/neil3d/excel2json/releases 完整项目源代码下载:https://github.com/neil3d/excel2json ...
- docker 基础之镜像加速
国内访问 Docker Hub 有时会遇到困难,此时可以配置镜像加速器 对于使用 systemd 的系统,用 systemctl enable docker 启用服务后,编辑 /etc/systemd ...
- 本地服务器上挂载A目录到B目录
原因: 由于某个分区满了,切磁盘无法扩大分区空间,但是项目依赖该分区,需要继续像该分区存储文件,此时其他分区还有很大的空间,使用挂载的方式,在有空间的分区创建新目录,将新目录挂载到源目录下即可. 执行 ...
- JAVA核心技术I---JAVA基础知识(内部类)
一:内部类概述 (一)定义 内部类(Inner Class)是定义在其他类中或方法中的类,包含内部类的类通常称作Enclosing Class 内部类的功能通常与包含它的类的功能有紧密的关联 内部类的 ...
- SNMP支持IPv6
SNMP Trap 网上好像很少提到ipv6的配置文件格式,这个配置文件的格式应该为: trap2sink udp6:[fec0::]:: 创建监听的函数入口:netsnmp_udp_transp ...
- Sqlserver批量生成10w不重复8位数字
项目中需要批量生成100W不重复的8位数,百度了一大把,修改成了如下Sql,做下笔记,希望对看到的朋友有帮助(下面是生成10W条,条数自己改,性能还可以) 表名:makeExtensionCode 字 ...