洛谷P5155 [USACO18DEC]Balance Beam(期望,凸包)
你以为它是一个期望dp,其实它是一个凸包哒!
设平衡木长度为\(L\),把向右走平衡木那个式子写一下:
\[dp[i]=\frac{dp[i+1]+dp[i-1]}{2}\]
然后会发现这是一个等差数列,显然有\(dp[0]=0,dp[L]=1\)
所以\(dp_{i\rightarrow L}=\frac{i}{L}\)
向左走同理:\(dp_{i\rightarrow 1}=\frac{L-i}{L}\)
令停止点为直接从这个点跳下去能得到期望报酬最高的点,设点\(i\)左右两端的停止点分别为\(l\)和\(r\)
则贡献\(f_i=a_l*\frac{r-i}{r-l}+a_r*\frac{i-l}{r-l}\),可以看成是\((l,a_l),(r,a_r)\)组成的线段与直线\(x=i\)的纵坐标
思考一下会发现所有停止点构成一个上凸包
式子写错调了我好久QAQ
代码:
#include <bits/stdc++.h>
#define N 100010
#define ll long long
#define db double
#define int long long
using namespace std;
int s[N],l[N],r[N];ll a[N];
bool pd(int x,int y,int z){ return (a[y]-a[x])*(z-y)<(a[z]-a[y])*(y-x); }
bool vis[N];
const ll bs=1e5;
main(){
    int n,i,top=0,j;
    scanf("%lld",&n);
    for(i=1;i<=n;++i) scanf("%lld",&a[i]);
    s[++top]=0;
    for(i=1;i<=n+1;++i){
        while(top>1 && pd(s[top-1],s[top],i)) top--;
        s[++top]=i;
    }
    for(i=1;i<=n;++i) a[i]*=bs;
    for(i=1;i<top;++i){
        l[s[i]]=r[s[i]]=s[i];
        for(j=s[i]+1;j<s[i+1] && j<=n;++j)
            l[j]=s[i],r[j]=s[i+1];
    }
    for(int i=1;i<=n;++i){
        if(l[i]==r[i])printf("%lld\n",a[i]);
        else printf("%lld\n",(a[l[i]]*(r[i]-i)+a[r[i]]*(i-l[i]))/(r[i]-l[i]));
    }
}洛谷P5155 [USACO18DEC]Balance Beam(期望,凸包)的更多相关文章
- p5155 [USACO18DEC]Balance Beam
		传送门 分析 https://www.luogu.org/blog/22112/solution-p5155 代码 #include<bits/stdc++.h> using namesp ... 
- 题解-洛谷P4724 【模板】三维凸包
		洛谷P4724 [模板]三维凸包 给出空间中 \(n\) 个点 \(p_i\),求凸包表面积. 数据范围:\(1\le n\le 2000\). 这篇题解因为是世界上最逊的人写的,所以也会有求凸包体积 ... 
- Luogu5155 [USACO18DEC]Balance Beam
		题目链接:洛谷 这道题看起来是个期望题,但是其实是一道计算几何(这种题太妙了) 首先有一个很好的结论,在一个长度为$L$的数轴上,每次从$x$处出发,不停地走,有$\frac{x}{L}$的概率从右端 ... 
- 题解-USACO18DEC Balance Beam详细证明
		(翻了翻其他的题解,觉得它们没讲清楚这个策略的正确性) Problem 洛谷5155 题意概要:给定一个长为\(n\)的序列,可以选择以\(\frac 12\)的概率进行左右移动,也可以结束并得到当前 ... 
- Luogu5155 USACO18DEC Balance Beam(概率期望+凸包)
		假设已经求出了在每个点的最优期望收益,显然最优策略是仅当移动一次后的期望收益>当前点收益时移动.对于初始点,其两边各存在一个最近的不满足上述条件的位置,因此从初始点开始随机游走,直到移动到这两个 ... 
- [USACO18DEC]Balance Beam
		题目链接:这里 或者这里 答案是很显然的,记\(g(i)\)为在\(i\)下平衡木时的期望收益 那么\(g(i)=max(f(i),\frac{g(i-1)+g(i+1)}{2})\) 好了做完了 T ... 
- 题解 [USACO18DEC]Balance Beam
		被概率冲昏的头脑~~~ 我们先将样例在图上画下来: 会发现,最大收益是: 看出什么了吗? 这不就是凸包吗? 跑一遍凸包就好了呀,这些点中,如果i号点是凸包上的点,那么它的ans就是自己(第二个点),不 ... 
- 洛谷P4561 [JXOI2018]排序问题(二分 期望)
		题意 题目链接 Sol 首先一种方案的期望等于它一次排好的概率的倒数. 一次排好的概率是个数数题,他等于一次排好的方案除以总方案,也就是\(\frac{\prod cnt_{a_i}!}{(n+m)! ... 
- 洛谷P1850 换教室 [noip2016] 期望dp
		正解:期望dp 解题报告: 哇我发现我期望这块真的布星,可能在刷了点儿NOIp之后会去搞一波期望dp的题...感觉连基础都没有打扎实?基础概念都布星! 好那先把这题理顺了嗷qwq 首先我们看到期望就会 ... 
随机推荐
- tomcat 控制台中文乱码问题
			1.找到${CATALINA_HOME}/conf/logging.properties2.添加语句:java.util.logging.ConsoleHandler.encoding = GBK 3 ... 
- Java多线程知识整理
			多线程 1. 多线程基础 多线程状态转换图 普通方法介绍 yeild yeild,线程让步.是当前线程执行完后所有线程又统一回到同一起跑线.让自己或者其他线程运行,并不是单纯的让给其他线程. join ... 
- GraphQL基础篇
			最近参与了一个大型项目,大型项目随着系统业务量的增大,不同的应用和系统共同使用着许多的服务接口API,而随着业务的变化和发展,不同的应用对相同资源的不同使用方法最终会导致需要维护的服务API数量呈现爆 ... 
- 【AO笔记】关于创建IFeatureClass中的参考系设置——不能为null也不能为IUnknownCoodinateSystem
			创建一个要素类是很简单的,只需要获取一枚IFeatureWorkspace或者一个IFeatureDataset,然后调用其CreateFeatureClass()即可. 这个CreateFeatur ... 
- 评估指标【交叉验证&ROC曲线】
			# -*- coding: utf-8 -*- """ Created on Mon Sep 10 11:21:27 2018 @author: zhen "& ... 
- HDFS深度历险 之 从客户端逻辑看HDFS写入机制
			说明 除了标注之外,本文纯属原创,转载请注明出处:https://www.jianshu.com/p/ea6ef5f5b868, https://www.cnblogs.com/monkeyteng/ ... 
- Anaconda在Windows上安装不上原因
			倒腾了一下午安装Anaconda,[所有程序]中只有一个Anaconda的目录,目录中只有一个anaconda prompt,最后发现是因为环境中原先就安装了Java环境,将之前安装的java环境卸载 ... 
- A customized combobox with JQuery
			要求实现一个轻量级的在客户端筛选的combobox,支持大数据量(超过1000个items),能快速检索内容,并支持数据的设置和活动等基本操作.在这之前尝试过使用Jquery UI的Autocompl ... 
- sql优化个人总结(全)
			sql优化总结--博客 第一次自己写博客,以后要坚持每掌握一个技能点,就要写一篇博客出来,做一个不满足于一个只会写if...else的程序员. 最近三个月入职了一家新的公司,做的是CRM系统,将公司多 ... 
- oracle知识点总结基础篇1
			最近学习了Oracle,对学习内容挑干的进行总结! 1.准备工作:学习Oracle首先就是安装环境.我装的是oracle11g. 2.安装完成之后在dos窗口中,输入 sqlplus 再输入用户名和 ... 
