随机挑战总结 Part3

2024-01-30 10:08
文章标签 总结 随机 挑战 part3

本文主要是介绍随机挑战总结 Part3,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

今天纪中没有题目,所以闲的发慌又来随机跳题。
上次由于被 d a l a o dalao dalao们嘲讽说题目太简单了 q w q qwq qwq,所以这次跳的是3道紫题。
然而我的题目还是最简单的 q w q qwq qwq
再次准备被 d a l a o dalao dalao嘲讽 ( 2 / 2147483647 ) (2/2147483647) (2/2147483647)
主要还是太菜了。本来跳的第三题是一个分层图最短路,然后敲完样例没过,调试的我都要被恶心死了。还要跑两遍,读入字符串,而且我的方法还是会 M L E MLE MLE q w q qwq qwq然后两位大爷为了不让我这么尴尬就让我换了一道题结果又是一道水题。
随机跳题总结:我永远是最菜的OIer qwq \color{white}\texttt{随机跳题总结:我永远是最菜的OIer qwq} 随机跳题总结:我永远是最菜的OIer qwq


题目:

  1. P 3554 [ P O I 2013 ] L U K − T r i u m p h a l a r c h P3554\ [POI2013]LUK-Triumphal\ arch P3554 [POI2013]LUKTriumphal arch
  2. P 4838 P4838 P4838 P哥破解密码
  3. P 3259 [ J L O I 2014 ] P3259\ [JLOI2014] P3259 [JLOI2014]路径规划(放弃 q w q qwq qwq
  4. P 1712 [ N O I 2016 ] P1712\ [NOI2016] P1712 [NOI2016]区间

T1T2水的一匹,感觉要被嘲讽 q w q qwq qwq

在这里插入图片描述
Link:XXY巨爷的随机跳题Part3总结 \color{red}\texttt{Link:XXY巨爷的随机跳题Part3总结} Link:XXY巨爷的随机跳题Part3总结


题解

T1 P 3554 [ P O I 2013 ] L U K − T r i u m p h a l a r c h P3554\ [POI2013]LUK-Triumphal\ arch P3554 [POI2013]LUKTriumphal arch

一道很简单的二分答案+树形 d p dp dp的题目。码量还贼小。
难度☆☆,不知道怎么被评上紫题的。
戳我:Link \color{blue}\texttt{戳我:Link} 戳我:Link


T2 P 4838 P4838 P4838 P哥破解密码

显然矩阵乘法,思路也很简单,不难想,写完结构体感觉为所欲为。
难度☆☆,不知道怎么被评上紫题的。
戳我:Link \color{blue}\texttt{戳我:Link} 戳我:Link


(伪)T3 P 3259 [ J L O I 2014 ] P3259\ [JLOI2014] P3259 [JLOI2014]路径规划

发现是分成图最短路,于是赶快去洛谷敲了一发 分层图最短路的模板。
然后来做这道题,发现这不是一般的恶心啊啊啊啊啊啊啊啊啊啊啊。
难度☆☆☆☆☆,依然不知道怎么被评上紫题的不应该是黑题吗
WA代码就不放了,改天闲的发慌再来改吧。


T3 P 1712 [ N O I 2016 ] P1712\ [NOI2016] P1712 [NOI2016]区间

思维好题。退一番发现可以用线段树维护。然后就在线段树的标记细节上搞了比较久,最终总算是搞出来了。
难度☆☆☆,算是正常的紫题了。
戳我:Link \color{blue}\texttt{戳我:Link} 戳我:Link


代码

T1
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;const int N=300010;
int n,x,y,tot,l,r,mid,f[N],head[N];struct edge
{int to,next;
}e[N*2];void add(int from,int to)
{e[++tot].to=to;e[tot].next=head[from];head[from]=tot;
}void dp(int x,int fa)
{int sum=0;for (int i=head[x];~i;i=e[i].next){int y=e[i].to;if (y!=fa){dp(y,x);sum+=f[y]+1;}}f[x]=max(0,sum-mid);
}int main()
{memset(head,-1,sizeof(head));scanf("%d",&n);for (int i=1;i<n;i++){scanf("%d%d",&x,&y);add(x,y); add(y,x);}l=0; r=n-1;while (l<=r){mid=(l+r)/2;dp(1,0);if (!f[1]) r=mid-1;else l=mid+1;}printf("%d\n",r+1);return 0;
}
T2
#include <cstdio>
#include <cstring>
using namespace std;
typedef long long ll;const ll MOD=19260817;
int n,m;struct matrix
{ll a[4][4];
}f,A,a;matrix operator *(matrix a,matrix b)
{matrix c;memset(c.a,0,sizeof(c.a));for(int i=1;i<=3;i++)for(int j=1;j<=3;j++)for(int k=1;k<=3;k++)c.a[i][j]=(c.a[i][j]+a.a[i][k]*b.a[k][j])%MOD;return c;
}void power(int M)
{for (;M;M>>=1,a=a*a)if (M&1) f=f*a;
}int main()
{//A.a[1][3]=A.a[2][1]=A.a[3][1]=A.a[3][2]=A.a[3][3]=1;A.a[3][1]=A.a[1][2]=A.a[1][3]=A.a[2][3]=A.a[3][3]=1;scanf("%d",&m);while (m--){memcpy(a.a,A.a,sizeof(A.a));memset(f.a,0,sizeof(f.a));f.a[1][1]=f.a[1][3]=1;scanf("%d",&n);power(n-1);printf("%lld\n",(f.a[1][1]+f.a[1][2]+f.a[1][3])%MOD);}return 0;
}
T3
#include <cstdio>
#include <algorithm>
using namespace std;const int N=500010,Inf=2e9;
int n,m,maxn,ans=Inf,b[N*2];struct node
{int l,r,len;
}a[N];struct Tree
{int l,r,maxn,lazy;
}tree[N*8];bool cmp(node x,node y)
{return x.len<y.len;
}void build(int x)
{if (tree[x].l==tree[x].r) return;int mid=(tree[x].l+tree[x].r)/2;tree[x*2].l=tree[x].l;tree[x*2].r=mid;tree[x*2+1].l=mid+1;tree[x*2+1].r=tree[x].r;build(x*2); build(x*2+1);
}void pushdown(int x)
{if (tree[x].lazy){tree[x*2].lazy+=tree[x].lazy;tree[x*2+1].lazy+=tree[x].lazy;tree[x*2].maxn+=tree[x].lazy;tree[x*2+1].maxn+=tree[x].lazy;tree[x].lazy=0;}
}void add(int x,int l,int r)
{if (tree[x].l==l && tree[x].r==r){tree[x].lazy++;tree[x].maxn++;return;}pushdown(x);int mid=(tree[x].l+tree[x].r)/2;if (r<=mid) add(x*2,l,r);else if (l>mid) add(x*2+1,l,r);else add(x*2,l,mid),add(x*2+1,mid+1,r);tree[x].maxn=max(tree[x*2].maxn,tree[x*2+1].maxn);
}void del(int x,int l,int r)
{if (tree[x].l==l && tree[x].r==r){tree[x].lazy--;tree[x].maxn--;return;}pushdown(x);int mid=(tree[x].l+tree[x].r)/2;if (r<=mid) del(x*2,l,r);else if (l>mid) del(x*2+1,l,r);else del(x*2,l,mid),del(x*2+1,mid+1,r);tree[x].maxn=max(tree[x*2].maxn,tree[x*2+1].maxn);
}int main()
{scanf("%d%d",&n,&m);for (int i=1;i<=n;i++){scanf("%d%d",&a[i].l,&a[i].r);a[i].len=a[i].r-a[i].l;b[2*i-1]=a[i].l; b[2*i]=a[i].r;}sort(b+1,b+1+n+n);int tot=unique(b+1,b+1+n+n)-b-1;for (int i=1;i<=n;i++){a[i].l=lower_bound(b+1,b+1+tot,a[i].l)-b;a[i].r=lower_bound(b+1,b+1+tot,a[i].r)-b;if (a[i].r>maxn) maxn=a[i].r;}tree[1].l=1; tree[1].r=maxn;build(1);sort(a+1,a+1+n,cmp);for (int r=1,l=0;r<=n;r++){add(1,a[r].l,a[r].r);if (tree[1].maxn>=m){do{l++;del(1,a[l].l,a[l].r);}while (tree[1].maxn>=m);if (a[r].len-a[l].len<ans) ans=a[r].len-a[l].len;}}if (ans<Inf) printf("%d\n",ans);else printf("-1");return 0;
}

这篇关于随机挑战总结 Part3的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/659905

相关文章

Kubernetes常用命令大全近期总结

《Kubernetes常用命令大全近期总结》Kubernetes是用于大规模部署和管理这些容器的开源软件-在希腊语中,这个词还有“舵手”或“飞行员”的意思,使用Kubernetes(有时被称为“... 目录前言Kubernetes 的工作原理为什么要使用 Kubernetes?Kubernetes常用命令总

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python中实现进度条的多种方法总结

《Python中实现进度条的多种方法总结》在Python编程中,进度条是一个非常有用的功能,它能让用户直观地了解任务的进度,提升用户体验,本文将介绍几种在Python中实现进度条的常用方法,并通过代码... 目录一、简单的打印方式二、使用tqdm库三、使用alive-progress库四、使用progres

使用C#如何创建人名或其他物体随机分组

《使用C#如何创建人名或其他物体随机分组》文章描述了一个随机分配人员到多个团队的代码示例,包括将人员列表随机化并根据组数分配到不同组,最后按组号排序显示结果... 目录C#创建人名或其他物体随机分组此示例使用以下代码将人员分配到组代码首先将lstPeople ListBox总结C#创建人名或其他物体随机分组

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

跨国公司撤出在华研发中心的启示:中国IT产业的挑战与机遇

近日,IBM中国宣布撤出在华的两大研发中心,这一决定在IT行业引发了广泛的讨论和关注。跨国公司在华研发中心的撤出,不仅对众多IT从业者的职业发展带来了直接的冲击,也引发了人们对全球化背景下中国IT产业竞争力和未来发展方向的深思。面对这一突如其来的变化,我们应如何看待跨国公司的决策?中国IT人才又该如何应对?中国IT产业将何去何从?本文将围绕这些问题展开探讨。 跨国公司撤出的背景与

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;