早上打一半就回家了...

  T1傻逼题不说了...而且我的写法比题解要傻逼很多T T

  T2可以发现,我们强制最大值所在的块是以左上为边界的倒三角,然后旋转4次就可以遍历所有的情况。所以二分极差,把最大值所能扩展到的(mp[i][j]+mid>=mx)最大倒三角求出来,剩下的数减去最小值判断一下是否小于等于极差,如果是的话答案可行。

#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
#define ll long long
using namespace std;
const int maxn=,inf=1e9;
int mn,mx;
int n[],m[],mp[][maxn][maxn];
bool v[maxn][maxn];
void read(int &k)
{
int f=;k=;char c=getchar();
while(c<''||c>'')c=='-'&&(f=-),c=getchar();
while(c<=''&&c>='')k=k*+c-'',c=getchar();
k*=f;
}
void rotate(int x,int y)
{
for(int i=;i<=n[x];i++)
for(int j=;j<=m[x];j++)
mp[y][j][n[x]-i+]=mp[x][i][j];
n[y]=m[x];m[y]=n[x];
}
bool check(int x,int mid)
{
memset(v,,sizeof(v));
int now=m[x];
for(int i=;i<=n[x];i++)
for(int j=;j<=now;j++)
if(mp[x][i][j]+mid<mx){now=j-;break;}
else v[i][j]=;
for(int i=n[x];i;i--)
for(int j=m[x];j;j--)
if(v[i][j])break;
else if(mp[x][i][j]-mid>mn)return ;
return ;
}
int main()
{
read(n[]);read(m[]);mn=inf;
for(int i=;i<=n[];i++)for(int j=;j<=m[];j++)read(mp[][i][j]),mx=max(mx,mp[][i][j]),mn=min(mn,mp[][i][j]);
rotate(,);rotate(,);rotate(,);
int l=,r=mx-mn;
while(l<r)
{
int mid=(l+r)>>;
if(check(,mid)||check(,mid)||check(,mid)||check(,mid))r=mid;
else l=mid+;
}
printf("%d\n",l);
return ;
}

  T3超喵的题啊,虽然标程好像出了点小偏差,已经跟管理员反馈了,但是现在暂时还没有更正,还是先水一篇博客要紧...

  首先要知道扩展欧拉定理...

  我们知道p<=2e7,所以可以先预处理出2e7内的phi(我写个埃式筛怎么比线性筛慢那么多T T)。因为一个数最多经过log次求phi的操作就会变成1,当变成1的时候后面的数就没有意义了,所以对于一个区间的询问,我们可以递归地计算指数,直到1就返回1,或者直到区间扫完就返回当前位置的值,效率O(logP)。但是我们怎么判断当前指数是否大于phi(p)呢,可以发现,所以我们只要知道后5位的数就可以判断指数是否大于phi(p)了。然后一边递归一边快速幂,用BIT维护区间修改,单点查询,就可以了。

  这个代码现在只有90分,等管理员更正数据后就能AC了...

  UPD:数据已更正,状态里瞬间只剩下我一个人AC...

  UPD:改成线性筛快了好多...

#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
#define ll long long
using namespace std;
const int maxn=,inf=1e9,lim=2e7;
int n,m,ty,x,y,z,cnt;
int phi[],v[maxn],prime[];
ll tree[maxn],a[maxn];
bool vis[];
void read(int &k)
{
int f=;k=;char c=getchar();
while(c<''||c>'')c=='-'&&(f=-),c=getchar();
while(c<=''&&c>='')k=k*+c-'',c=getchar();
k*=f;
}
inline int lowbit(int x){return x&-x;}
inline void add(int x,int delta){for(;x<=n;x+=lowbit(x))tree[x]+=delta;};
inline ll querysum(int x){ll sum=;for(;x;x-=lowbit(x))sum+=tree[x];return sum;}
inline ll query(int x)
{
if(v[x]==m+)return a[x];
v[x]=m+;return a[x]=querysum(x);
}
inline int power(int a,int b,int mod)
{
if(!a)return ;int ans=;
for(;b;b>>=,a=1ll*a*a%mod)
if(b&)ans=1ll*ans*a%mod;
return ans;
}
int solve(int l,int r,int mod)
{
if(mod==)return ;
ll now=query(l)%mod;if(!now)return ;if(l==r)return now;
int nxt=min(l+,r);
for(int i=l+;i<nxt;i++)if(query(i)==){nxt=r=i;break;}
ll last=query(nxt),x;
if(last>=phi[mod])return power(now,solve(l+,r,phi[mod])+phi[mod],mod);
for(int i=nxt-;i>l;i--)
{
ll mi=last;last=;x=query(i);
for(int j=;j<=mi;j++)
{
last*=x;
if(last>=phi[mod])return power(now,solve(l+,r,phi[mod])+phi[mod],mod);
}
}
return power(now,solve(l+,r,phi[mod]),mod);
}
inline void getphi()
{
phi[]=;
for(int i=;i<=lim;i++)
{
if(!vis[i])prime[++cnt]=i,phi[i]=i-;
for(int j=;j<=cnt;j++)
{
int t=i*prime[j];if(t>lim)break;
vis[t]=;
if(i%prime[j]==){phi[t]=phi[i]*prime[j];break;}
phi[t]=phi[i]*(prime[j]-);
}
}
}
int main()
{
getphi();read(n);read(m);int pre=;
for(int i=;i<=n;i++)read(x),add(i,x-pre),pre=x;
while(m--)
{
read(ty);read(x);read(y);read(z);
if(ty==)add(x,z),add(y+,-z);
else printf("%d\n",solve(x,y,z)%z);
}
return ;
}

洛谷10月月赛R2·浴谷八连测R3题解的更多相关文章

  1. 洛谷4月月赛R2

    洛谷4月月赛R2 打酱油... A.koishi的数学题  线性筛约数和就可以\(O(N)\)了... #include <iostream> #include <cstdio> ...

  2. 【LGR-054】洛谷10月月赛II

    [LGR-054]洛谷10月月赛II luogu 成功咕掉Codeforces Round #517的后果就是,我\(\mbox{T4}\)依旧没有写出来.\(\mbox{GG}\) . 浏览器 \( ...

  3. 洛谷10月月赛II题解

    [咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...

  4. 洛谷10月月赛Round.3

    Rank11:260=60+100+100 P2409 Y的积木 题目背景 Y是个大建筑师,他总能用最简单的积木拼出最有创意的造型. 题目描述 Y手上有n盒积木,每个积木有个重量.现在他想从每盒积木中 ...

  5. 洛谷10月月赛Round.1| P3398 仓鼠找sugar[LCA]

    题目描述 小仓鼠的和他的基(mei)友(zi)sugar住在地下洞穴中,每个节点的编号为1~n.地下洞穴是一个树形结构.这一天小仓鼠打算从从他的卧室(a)到餐厅(b),而他的基友同时要从他的卧室(c) ...

  6. 洛谷10月月赛Round.1| P3400 仓鼠窝[单调栈]

    题目描述 萌萌哒的Created equal是一只小仓鼠,小仓鼠自然有仓鼠窝啦. 仓鼠窝是一个由n*m个格子组成的行数为n.列数为m的矩阵.小仓鼠现在想要知道,这个矩阵中有多少个子矩阵!(实际上就是有 ...

  7. 洛谷10月月赛Round.1| P3399 丝绸之路 [DP]

    题目背景 张骞于公元前138年曾历尽艰险出使过西域.加强了汉朝与西域各国的友好往来.从那以后,一队队骆驼商队在这漫长的商贸大道上行进,他们越过崇山峻岭,将中国的先进技术带向中亚.西亚和欧洲,将那里的香 ...

  8. 【LGR-060】洛谷10月月赛 I div.1&div.2

    Preface 一边打一边写作文打的像shit,T2失智严重特判错了233 Orz Div1 Rank2的foreverlastnig聚聚,顺便说一句显然Luogu的比赛质量比以往显著提高了啊 以下题 ...

  9. 洛谷 4933 洛谷10月月赛II T2 大师

    [题解] f[i][j]表示最后一个数为h[i],公差为j的等差数列的个数.n方枚举最后一个数和倒数第二个数转移即可.注意公差可能为负数,需要移动为正数再作为下标. #include<cstdi ...

随机推荐

  1. 四、Django之模型与管理后台-Part 2

    一.数据库安装 打开mysite/settings.py配置文件,这是整个Django项目的设置中心.Django默认使用SQLite数据库,因为Python源生支持SQLite数据库,所以你无须安装 ...

  2. Phaser3让超级玛丽实现轻跳、高跳及加上对应的跳跃声音

      mario jumper 在线测试地址:http://www.ifiero.com/uploads/phaserjs3/jumper/ 空格键:轻按:跳低 ,长按:跳高键盘:--> 向右 , ...

  3. Hackerank-Array-NewYearChaos

    题目背景描述 新年第一天,N 个人排队坐过山车.每个人穿有带编号的衣服 \([1, 2, 3, ...]\). 因为排队时间太久,有人发现给前面相邻的人喂一颗糖,就可以和他交换位置,而每人手里只有两颗 ...

  4. [题解] 洛谷 P3603 雪辉

    模拟赛中遇到了这个题,当时我这个沙雕因为把一个\(y\)打成了\(x\)而爆零.回来重新写这道题,莫名其妙的拿了rank1... 我的解法与其他几位的题解有些不同我太蒻了.并没有选取所谓的关键点,而是 ...

  5. Powershell按文件最后修改时间删除多余文件

    Powershell按文件最后修改时间删除多余文件 1. 删除目录内多余文件,目录文件个数大于$count后,按最后修改时间倒序排列,删除最旧的文件. Sort-Object -Property La ...

  6. 王者荣耀交流协会Beta发布文案美工展示博客

    logo: 我们的logo是蓝底白字,非常简洁大气的设计感,上面印有我们的软件名称,更好的直观的彰显了我们的主题.我们的软件就是要迎合使用者,给使用者更加方便快捷的工作体验,更好的衡量自己的时间分配. ...

  7. 王者荣耀交流协会第一次Scrum立会

    工作照片: scrum master:高远博 时间跨度;2017/10/13 6:04-6:34 地点:一食堂二楼两张桌子旁 立会内容; 昨天的成绩;昨天商议了今天的开会的时间.地点 今天的计划;讨论 ...

  8. 博弈---ZOJ 3057 Beans Game(DP博弈)

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3057 有豆类三个桩.TT和DD挑选任意数量的豆子从任何两堆轮流任何桩或相同 ...

  9. lintcode395-硬币排成线 II

    395-硬币排成线 II 有 n 个不同价值的硬币排成一条线.两个参赛者轮流从左边依次拿走 1 或 2 个硬币,直到没有硬币为止.计算两个人分别拿到的硬币总价值,价值高的人获胜. 请判定 第一个玩家 ...

  10. Struts2(六)

    以下内容是基于导入struts2-2.3.32.jar包来讲的 1.OGNL OGNL是Object-Graph Navigation Language的缩写,全称为对象图导航语言,是一种功能强大的表 ...