#include <bits/stdc++.h>
using namespace std;
const int N = 2e5+10;
double a[N];
int fa[N];
int sz[N];
double avg[N];
int n,m;
int find(int x)
{
return x==fa[x]?x:fa[x]=find(fa[x]);
}
void merge(int x,int y)
{
int fx = find(x);
int fy = find(y);
if(fx==fy)return ;
if(fx<fy)swap(fx,fy);
avg[fx] = ((double)sz[fx]*avg[fx]+(double)sz[fy]*avg[fy])/(double)(sz[fx]+sz[fy]);
sz[fx]+=sz[fy];
fa[fy]=fx;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>a[i];
fa[i]=i;
sz[i]=1;
avg[i]=a[i];
}
for(int i=1;i<=m;i++)
{
int op;
cin>>op;
if(op==1)
{
int l,r;
cin>>l>>r;
int L = l;
int R = r;
int ans = find(l);
while(find(ans)!=find(r))
{
merge(ans,ans+1);
ans=find(ans);
}
}
else
{
int x;
cin>>x;
printf("%.7lf\n",avg[find(x)]);
}
}
}
并查集

京公网安备 11010502036488号