首页 > 其他分享 >YbtOJ 「数学基础」第6章 期望问题

YbtOJ 「数学基础」第6章 期望问题

时间:2022-08-31 00:55:51浏览次数:66  
标签:code 期望 int YbtOJ d% 数学 ans const main

既然被提醒了不要咕咕咕那就先写一点(?
不过过几天估计就又咕啦。
深刻体会到了写完几道题统一补博客的难受。
期望题 LaTeX 好难打诶可能写得简略点qaq

例题1.单选错位

emmm 好像没啥可说(?

code
#include<bits/stdc++.h>
using namespace std; 
const int N=1e7+5;
int n,A,B,C,a[N];
double ans;
int main()
{
	scanf("%d%d%d%d%d", &n, &A, &B, &C, a + 1);
	for (int i = 2; i <= n; i++)
		a[i] = ((long long) a[i - 1] * A + B) % 100000001;
	for (int i = 1; i <= n; i++)
		a[i] = a[i] % C + 1;
	ans+=1.0/max(a[1],a[n]);
	for(int i=2;i<=n;i++)
	{
		ans+=1.0/max(a[i],a[i-1]);
	}
	printf("%.3lf\n",ans);
	return 0;
}

例题2.期望分数

同时开两个变量维护当前的期望得分和期望连续o的长度。

code
#include<bits/stdc++.h>
using namespace std;
const int N=3e5+5;
int n;
double len,ans;
char s[N];
int main()
{
	scanf("%d%s",&n,s+1);
	for(int i=1;i<=n;i++)
	{
		if(s[i]=='o')
		{
			ans+=len*2+1;
			len++;
		}
		else if(s[i]=='x') len=0;
		else
		{
			ans+=(len*2+1)/2.0;
			len=(len+1)/2.0;
		}
	}
	printf("%.4lf\n",ans);
	return 0;
}

例题3.路径长度

原题 lg P4316 绿豆蛙的归宿。
建反图进行拓扑排序,从终点倒推。

code
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+5;
int n,m,in[N],out[N];
double E[N];
struct node{
	int nxt,to,w;
}e[N];
int head[N],cnt;
void add(int u,int v,int w){
	e[++cnt]={head[u],v,w};head[u]=cnt;
}
queue<int> q;
int main()
{
	scanf("%d%d",&n,&m);
	for(int i=1,u,v,w;i<=m;i++) 
	{
		scanf("%d%d%d",&u,&v,&w);
		add(v,u,w);in[u]++;out[u]++;
	}
	E[n]=0;
	for(int i=1;i<=n;i++) if(!in[i]) q.push(i);
	while(!q.empty())
	{
		
		int u=q.front();q.pop();
		//cout<<u<<endl;
		for(int i=head[u];i;i=e[i].nxt)
		{
			int v=e[i].to;
			E[v]+=(E[u]*1.0+e[i].w)*1.0/out[v];
			if(--in[v]==0) q.push(v);
		}
	}
	printf("%.2lf\n",E[1]);
	return 0;
}

1.比赛得分

分别计算两队的期望得分。
对于 A 队第 x 个人,对答案贡献为 \(\frac{1}{n}\Sigma_{B_y<A_x}(A_x-B_y)^2\) 。
把平方展开,对序列排序后 y 的取值变为连续一段,指针维护。

code
#include<bits/stdc++.h>
using namespace std; 
const int N=1e7+5;
int n,A,B,C,a[N];
double ans;
int main()
{
	scanf("%d%d%d%d%d", &n, &A, &B, &C, a + 1);
	for (int i = 2; i <= n; i++)
		a[i] = ((long long) a[i - 1] * A + B) % 100000001;
	for (int i = 1; i <= n; i++)
		a[i] = a[i] % C + 1;
	ans+=1.0/max(a[1],a[n]);
	for(int i=2;i<=n;i++)
	{
		ans+=1.0/max(a[i],a[i-1]);
	}
	printf("%.3lf\n",ans);
	return 0;
}

2.电影问题

先看 \(i\) 再看 \(j\) 对答案的贡献为 \(l_i\times \frac{x_i}{y_i}\times \frac{y_j-x_j}{y_j}\)。
按照上述贡献的大小对原序列排序即为最大期望。

code
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N=2e5+5;
const int mod=1004535809;
int n,f[N],g[N];
struct node{
	int l,x,y;
}a[N];
bool cmp(node a,node b){
	int c=a.l*a.x*(b.y-b.x);
	int d=b.l*b.x*(a.y-a.x);
	return c>d;
}
int qpow(int n,int k)
{
	int ans=1;
	while(k)
	{
		if(k&1) ans=ans*n%mod;
		n=n*n%mod;k>>=1;
	}
	return ans;
}
signed main()
{
	scanf("%lld",&n);
	for(int i=1;i<=n;i++) scanf("%lld%lld%lld",&a[i].l,&a[i].x,&a[i].y);
	sort(a+1,a+n+1,cmp);
	for(int i=1;i<=n;i++)
	{
		int inv=qpow(a[i].y,mod-2);
		f[i]=((f[i-1]+a[i].l*(2*a[i].x-a[i].y)%mod*inv%mod+g[i-1]*(a[i].y-a[i].x)%mod*inv%mod)%mod+mod)%mod;
		g[i]=(g[i-1]+a[i].l*a[i].x%mod*inv%mod)%mod;
	}
	cout<<f[n]<<endl;
	return 0;
}

标签:code,期望,int,YbtOJ,d%,数学,ans,const,main
From: https://www.cnblogs.com/ying-xue/p/16641502.html

相关文章

  • 高斯超几何函数如何运作(数学)
    高斯超几何函数如何运作(数学)Photoby乔什·皮福德on不飞溅计算合流和高斯超几何函数的数值方法(arXiv)作者:约翰·W·皮尔逊,希恩·奥尔弗,梅森·波特抽......
  • 如果我讨厌数学,我应该学习计算机科学吗?
    我是不是该学习计算机科学如果我恨数学?有两部分。首先,没有太多的数学典型的CS程度。在UBC,CS学位需要达到分析三、线性代数,和统计数据。这是小与什么物......
  • 组合数学从入门到入土为安
    排列数:\(A_{n}^{m}\),\(n\)个数抽\(m\)个,不考虑这\(m\)个数的顺序。可以看成有\(m\)个盒子,第一个盒子有\(n\)种情况,第二个盒子有\(n-1\)种情况,第三个盒子有......
  • VBA中的数学公式
    Table3-5.VisualBasicmathfunctionsGeneralAbsExpFixIntLogRndSgnSqr  TrigonometricAtnCosSinTanFinancial......
  • Codeforces Round #287 (Div. 2) B. Amr and Pins(数学/思维)
    https://codeforces.com/contest/507/problem/B题目大意:Amr有一个半径为r、圆心在点(x,y)的圆。他希望圆心在新的位置(x',y')。在一个步骤中,Amr可以将一个大头针放在......
  • 扔骰子期望
    扔骰子可以选择扔到某个数的时候获得然后退出或者不拿走继续扔dp[i]表示扔第i次的时候的最大期望f[n]=1/6*(max(1,f(n-1))+max(2,f(n-2))+max(3,f(n-1))+max(4,f(n-......
  • [数学] 三角形三条中线围成的面积
    题目在\(\triangle\text{ABC}\)中,\(\text{AD,BE,CF}\)分别是\(\text{BC,AC,AB}\)边上的中线,且三线交于点\(\text{G}\)。设\(S_{\triangle\text{ABC}}=S\),求\(\text{A......
  • 信息学竞赛涉及到的必备数学知识
    2021年4月,全国青少年信息学奥林匹克竞赛大纲在NOI官网发布。为方便大家的查阅和收藏,把大纲的入门级、提高级和NOI级的数学部分整理了出来。入门级数学1.数及其运......
  • 数学一题(不定期咕咕咕)
    2022.8.27例:对于\(c>0\),当非零实数\(a,b\)满足\(4a^2-2ab+4b^2-c=0\),且使得\(|2a+b|\)最大时,\(\frac{3}{a}-\frac{4}{b}+\frac{5}{c}\)的最小值为__.分析:具体的......
  • 数学基础-SVD分解
                                      D    ......