首页 > 其他分享 >集训杂记

集训杂记

时间:2023-06-10 19:34:26浏览次数:42  
标签:概率 int sum que 杂记 小朋友 集训 dis

· 6/6

火星人 prefix

好神奇的一道题。
先回忆一下做这个题的时候都出现了哪些问题。

  • 首先是一些比较无脑的错误,比如传参的时候传错了,或者是分裂的时候左右点传反了
  • 然后就是分析的分裂左右子树的条件错了的问题
  • 最后就是这个\(hash\)的问题了

哈希的问题挺神奇,就是建点的时候要更新他那个哈希值,因为后面可能会直接调用就不会再更新了。

然后阶段性总结一下平衡树:
  • 平衡树维护的是线性区间的数的操作和统计
  • 可以像线段树那样维护一段值域,这一定是连续的,因为他会内部进行一个排序。
  • 因为父亲节点不是一个抽象出来的代表一个区间的节点,而是一个具体的节点,所以要维护相应的区间的东西的话还需要一定的抽象能力
  • 相较于线段树,平衡树可以完成维护较大的值域、插入、删除等操作,并且可以支持由下到上更新,也就是“上传标记”
  • 平衡树常数较大

· 6/7

星系探索

做这个题的教训就是:会正确分析时间复杂度真的很重要。
以为暴力求排名很费时间,导致浪费了两个小时瞎想。

概率与期望
  • 概率:某事发生的可能在总可能中的占比

\(p[A]\) : \(A\)的概率
\(p[AB]\) : \(AB\)同时发生的概率
\(p[A|B]\) : 在\(B\)发生时\(A\)的概率

全概率公式:

\[p[A]=\sum_i p[A|B_i] \]

条件概率:

\[p[A|B]=p[AB]/p[B] \]

由上可推
贝叶斯公式:

\[p[A|B]=p[B|A]*p[A]/p[B] \]

  • 期望:一个函数在不同情况下的取值的“调和值”

\(E[f[x]]=\sum_i f[B_i]*p[B_i]\)

妈耶我这个调和值的比喻实在是太恰当了
这个“调和值”就说明了期望的性质实际上跟权值是差不多的

期望的逆推

理解了好半天才明白的。

每一分钟从M个球中随便选出一个球涂成红色并放回,无论所选的球是不是红色。求将所有球涂成红色的时间的期望值。

可以设\(E[x]\)表示还有\(x\)个球时所需要的期望时间,则有\(E[M]=0\),要求的就是\(E[0]\)。

把每一个\(E[i]\)拆开来看,他有\(i/M\)的概率更新到\(E[i]\),又有\(1-i/M\)的概率更新到\(E[i+1]\)。

然后这么逆着推,就有了一种分解期望的方法:\(E[ 更新E[i]的部分 ]\) 和 \(E[ 更新E[i+1]的部分 ]\)。

然后分别计算,两边的权值分别从\(E[i]\)和\(E[i+1]\)逆推回来,再乘上相应的概率,就有:

\[E[i]=i/M*E[i]+(1-i/M)*E[i+1] \]

这么一个神奇的式子。

概率是什么玩意
太难啦

· 6/8

聪聪和可可

给出一个\(n\)个结点的无向图,其中\(A\)在\(M(mouse)\)点,\(B\)在\(C(cat)\)点,\(A\)每次向周围或本节点等概率移动一格,而\(B\)每次向靠近\(A\)的方向移动两格,在每分钟内\(B\)先走\(A\)再走,求\(B\)抓住\(A\)所用的期望时间。

首先看到\(n<=1000\)就考虑二维\(dp\)嘛

然后就知道居然还可以暴力地求出点与点之间的最短距离

打了一个\(dijistra\)之后被邢老师点拨之后发现\(bfs\)更快

第一次把\(dp\)转移式子推正确了

没想到最后还被选择编号较小的点背刺了一刀

守卫者的挑战

\(n\)次挑战,每次挑战有\(p_i\)的概率成功,成功后可以获得一个碎片或者一个有一定容量的背包,只有至少胜利\(L\)次并且所有得到的碎片都能用背包装下才算做胜利。求胜利的概率。

注意,因为最多只能获得\(200\)个碎片,所以获得的背包大于\(200\)的部分直接就不要了。实际容量只是\(-200\)到\(200\),再都加上个\(200\)就能用数组解决该问题了。

蚯蚓排队和这个有异曲同工之妙,都是用不着那么多的东西。

· 6/9

早上过来突然发现自己有了查看oi名字的权限?!
列队春游

有\(n\)个小朋友距离为一地站成一排,每个小朋友的视野为他到左边第一个身高大于等于他的小朋友的距离(特别地,第一个小朋友的视野为\(1\))。给出\(n\)个小朋友的身高,他们随机站,求视野总和的期望。

首先列式子,然后可以发现一个肥肠厉害的转化:
对于每个小朋友而言,设一个\(p[i]\)表示这个小朋友视野为\(i\)的概率。

\[E=\sum_{i=1}^n p[i]*i \]

\[E=\sum_{i=1}^n \sum_{j=i}^n p[j] \]

\[E=\sum_{i=1}^n p[x>=i] \]

然后要算的就变成了视野大于等于\(i\)的概率。

那么设一个\(k\)表示比当前这个小朋友高或者等高的人数。

则:

\[E=\sum_{i=1}^n \frac{(n-i+1)*A_{n-i}^k}{A_n^{k+1}} \]

然后对这个式子就可以展开,然后进行一系列的变化,然后就推出了这个式子:

\[E=\frac{n+1}{k+2} \]

可以推一推,需要用到这个式子:

\[\sum_{i=0}^n \binom{i}{k}=\binom{n+1}{k+1} \]

闲思

正如同那个排队一样,小的在前,大的在后,这是利益最大化;小的在后,大的在前,这是绝对公平。

· 6/10

今天居然真的没有比赛,我哭死
关于dijistra

这两种写法都是正确的:

while(!que.empty()){
	int y=que.top().second,cs=que.top().first;
	que.pop();
	if(dis[x][y]<cs) continue;
	for(int i=pre[y];i;i=ed[i].next){
		int z=ed[i].e;
		if(dis[x][z]>dis[x][y]+w[y][z]){
			dis[x][z]=dis[x][y]+w[y][z];
			que.push(make_pair(dis[x][z],z));
		}
	}
}
while(!que.empty()){
	int y=que.top().second,cs=que.top().first;
	que.pop();
	if(vi[y]) continue;
	vi[y]=1;
	for(int i=pre[y];i;i=ed[i].next){
		int z=ed[i].e;
		if(dis[x][z]>dis[x][y]+w[y][z]){
			dis[x][z]=dis[x][y]+w[y][z];
			que.push(make_pair(dis[x][z],z));
		}
	}
}

其原因就在于每个都保证了当前得到的点的存入队列的dis的确是正确的。

而所以这么写是不对的

while(!que.empty()){
	int y=que.top().second,cs=que.top().first;
	que.pop();
	for(int i=pre[y];i;i=ed[i].next){
		int z=ed[i].e;
		if(dis[x][z]>dis[x][y]+w[y][z]){
			dis[x][z]=dis[x][y]+w[y][z];
			if(!vi[z]){
				que.push(make_pair(dis[x][z],z));
				vi[z]=1;
			}
		}
	}
}

这么写直接就排序错了,输出的不是按真实值排名的点,蓝白点思想出大问题。

标签:概率,int,sum,que,杂记,小朋友,集训,dis
From: https://www.cnblogs.com/curly619/p/17459849.html

相关文章

  • 2023.6.10集训总结
    2023.6.10集训总结在5月中旬到现在,我们经历了几周的停课集训,期间我还前往NJU参加学科营活动,感受到自己与全国大佬的差距时,也学到了一些大赛策略和经验。现对停课期间的收获与反思进行总结。讲课这几天之内,Meatherm、yny和tqx分别来讲了2、2、4天的课。讲课主要以做例题为主,图论......
  • 【蓝桥杯集训·周赛】AcWing 第 95 场周赛
    第一题AcWing4873.简单计算一、题目1、原题链接4873.简单计算2、题目描述给定四个整数x1,y1,x2,y2,请你计算max(|x1−x2|,|y1−y2|)。输入格式第一行包含两个整数x1,y1。第二行包含两个整数x2,y2。输出格式一个整数,表示max(|x1−x2|,|y1−y2|)的值。数据范围前4个测试点......
  • loj6039. 「雅礼集训 2017 Day5」珠宝
    题目大意有\(n\)个物品,第\(i\)个费用为\(w_i\),价值为\(v_i\),对于\(k\in[1,m]\)求费用为\(m\)时能获得的最大价值。\(1\leqn\leq10^6,1\leqm\leq5\times10^4,1\leqw_i\leq300,1\leqv_i\leq10^9\)思路\(n\)很大,但\(w_i\)很小,于是我们考虑以其为突破口......
  • linux相关杂记
    find-namename,-inamename:文件名称符合name的文件。iname会忽略大小写find/etc-nameinit(精准查找)find/etc-name*init*(模糊查找,*任何字符)find/etc-nameinit???(模糊查找,?表示单个字符)find/etc-inameinit???(iname不区分大小写)-sizen:......
  • 【动态规划】【拉格朗日插值优化dp】集训队互测2012 calc
    【动态规划】【拉格朗日插值优化dp】集训队互测2012calc题目描述一个序列\(a_1,a_2,\dots,a_n\)是合法的,当且仅当:\(a_1,a_2,\dots,a_n\)都是\([1,k]\)中的整数。\(a_1,a_2,\dots,a_n\)互不相等。一个序列的值定义为它里面所有数的乘积,即\(a_1\timesa_2\times\dots......
  • P4451 [国家集训队]整数的lqp拆分
    Description求\[\begin{aligned}&\sum\prod_{i=1}^mF_{a_i}\\&m>0\\&a_1,a_2\ldotsa_m>0\\&a_1+a_2+\ldots+a_m=n\end{aligned}\]由于答案可能非常大,所以要对\(10^9+7\)取模。Solution题目中有整数拆分的部分,可以想到用生成函数的相关知识。设斐波那契数......
  • 「闲话随笔」期末考试与高考集训
    「闲话随笔」期末考试与高考集训点击查看目录目录「闲话随笔」期末考试与高考集训推歌:《崩坏:星穹铁道》OP星间旅行。原唱是茶理理,四舍五入就是星尘。今天是真挺闲的。上午11点左右放假,下午4点就回来了......
  • 【蓝桥杯集训·每日一题】AcWing 3805. 环形数组
    写在前面本人CSDN博客主页:这里一、题目1、原题链接3805.环形数组2、题目描述给定一个长度为n的环形数组a0,a1,…,an−1。现在要对该数组进行m次操作。操作分为以下两种:增值操作lrd,将区间[l,r]上的每个元素都增加d。求最小值操作lr,输出区间[l,r]内的所有元素的最小......
  • 【蓝桥杯集训·每日一题】AcWing 1079. 叶子的颜色
    写在前面本人CSDN博客主页:这里一、题目1、原题链接1079.叶子的颜色2、题目描述给一棵有m个节点的无根树,你可以选择一个度数大于1的节点作为根,然后给一些节点(根、内部节点、叶子均可)着以黑色或白色。你的着色方案应保证根节点到各叶子节点的简单路径上都至少包含一个有色节点,哪......
  • C/C++杂记:NULL与0的区别、nullptr的来历
    某些时候,我们需要将指针赋值为空指针,以防止野指针。 有人喜欢使用NULL作为空指针常量使用,例如:int*p=NULL;。也有人直接使用0值作为空指针常量,例如:int*p=0;。 前者可能觉得:NULL作为空指针常量,名字很形象,可读性较强。后者可能觉得:NULL并不是C/C++语言的关键字,而是一......