首页 技术 正文
技术 2022年11月11日
0 收藏 799 点赞 3,693 浏览 1577 个字

Description

51nod近日上线了用户满意度检测工具,使用高级人工智能算法,通过用户访问时间、鼠标轨迹等特征计算用户对于网站的满意程度。 现有的统计工具只能统计某一个窗口中,用户的满意程度的均值。夹克老爷想让你为统计工具添加一个新feature,即在统计均值的同时,计算窗口中满意程度的标准差和中位数(均值需要向下取整)。

Input

第一行是整数n与k,代表有n次操作,时间窗口大小为k。 
(1 <= n <= 10^6, 1 <= k <= 100)接下来的n行,每行代表一次操作。操作有“用户访问”、“查询均值”、“查询方差”、“查询中位数”四种。每行的第一个数代表操作类型。操作数1:用户访问
输入格式:<1, v>
用户的满意度v为闭区间[0, 100]中的任意整数。用户每访问一次,数据更新,移动统计窗口。操作数2:查询均值
输入格式:<2>
统计窗口内的用户满意度的均值。操作数3:查询方差
输入格式:<3>
统计窗口内用户满意度的方差操作数4:查询中位数
输入格式:<4>
统计窗口内用户满意度的中位数p.s. 在有查询请求时,窗口保证不为空
p.s.s. 有查询请求时,窗口可能不满

Output

对于“查询均值”、“查询方差”、“查询中位数”操作的结果,输出保留两位小数。

Input示例

12 3
1 1
1 2
1 3
2
3
4
1 4
1 5
1 6
2
3
4

Output示例

2.00
0.67
2.00
5.00
0.67
5.00其实难度主要在中位数……感谢隔壁大佬的思路。
因为v为闭区间[0, 100]中的任意整数,所以开个桶存一下就好了,每次查询中位数时,从0开始向后扫。
 #include<stdio.h>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
int n,sum,p,num,k,now,cnt,s[],a[];
int read()
{
int x=,f=;char c=getchar();
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
}
int main()
{
n=read();k=read();
while(n--)
{
p=read();
if(p==)
{
num=read();
a[++cnt]=num;
if(now==k)sum=sum-a[cnt-k]+num,s[a[cnt-k]]--;
else now++,sum+=num;
s[num]++;
}
else if(p==)printf("%.2lf\n",floor((double)sum/now));
else if(p==)
{
double w=(double)sum/now,ans=;
for(int i=cnt-now+;i<=cnt;i++)ans+=((double)a[i]-w)*((double)a[i]-w);
printf("%.2lf\n",ans/now);
}
else
{
if(now%)
{
int pos=now/+,ans=;
for(int i=;i<=;i++)
{
ans+=s[i];
if(ans>=pos)
{
printf("%.2lf\n",(double)i);
break;
}
}
}
else
{
int pos1=now/,pos2=now/+,st=-,ed=-,ans=;
for(int i=;i<=;i++)
{
ans+=s[i];
if(ans>=pos1&&st==-)st=i;
if(ans>=pos2&&ed==-)ed=i;
if(st!=-&&ed!=-)
{
printf("%.2lf\n",(double)(st+ed)/);
break;
}
}
}
}
}
return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,086
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,561
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,410
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,183
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,820
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,903