题目描述

定义两个数列:

$$S=\{S(1),S(2),...,S(n)\}\text{和}S_2\{S_2(1),S_2(2),...,S_2(n)\}$$

$$S(k)=(p_k\times k)\mod w,where\ p_k\ is\ the\ kth\ prime\ number$$

$$S_2(k)=S(k)+S(\left\lfloor\frac{k}{10}\right\rfloor+1)$$

令$M(i,j)$表示$S_2(i)$到$S_2(j)$的中位数(个数为奇数就是中间的数,否则为中间的两个数除以二)。现给定$n,k$,求:

$$\sum \limits_{i=1}^{n-k+1}M(i,i+k-1)$$


输入格式

输入只有一行,为三个正整数$n,k,w$(同题意)。


输出格式

输出只有一行,为所求的答案。如果答案不是整数,使用$.5$表示一半,否则用$.0$


样例

样例输入1:

100 10 10007

样例输出1:

387895.5

样例输入2:

100000 10000 10007

样例输出2:

897586519.5


数据范围与提示

对于$20\%$的数据,$n,k\leqslant 6,000$
对于另外$30\%$的数据,$n,k\leqslant 10,000$
对于另外$20\%$的数据,$w=3$
对于$100\%$的数据,$w\leqslant k\leqslant n\leqslant 10^7$


题解

首先,想说一下我在考试的时候的思路(毕竟对着这道$T1$刚了一个小时……)

$10^7$的数据范围$n\log n$可能差不多,于是我想到了$Splay$……

然后我就打了,还以为$A$了这道题。

然后忽然想到筛素数不能只筛到$10^7$,我们需要$10^7$素数,当场歇逼……

因为我发现要筛到$179424673$……

然后我就打算从$w$入手,推式子,找规律,最后啥也没发现,于是我只筛到了$10^7$,因为我觉得多了会$T$(学校$OJ$太菜)……

然而正解告诉我们,就是要筛到$179424673$……

因为$OJ$太才,于是标程$T$掉了,老师把时限开到了$4s$并重测,那些筛到$179424673$的人(本来都$T$飞了……)都拿到了$70$分,然而我差点跌出了前$10$……

擦干眼泪,笑面未来!!!

于是我们开始讲这道题……

思考一个类似莫队的思路,也类似滑动窗口叭~

维护一个指针指向中位数,挪动窗口时更新位置即可($k$是偶数时维护两个即可)。

总之这是一道卡常题,$\Theta(n\log n)$的做法就别想了,因为它是这样的$\downarrow$

然后我去尝试了正解$\downarrow$

其实我也不知道我到底哪里把常数给写大了,总之别人的是这样的$\downarrow$

然而我就筛个素数就$\downarrow$

时间复杂度:$\Theta(179424673+n)$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
int n,k,w;
int S1[10000001],S2[10000001];
int prime[10000001],cnt;
int t[10000001];
char vis[179424674];
double ans;
void pre_work()
{
for(int i=2;i<179424674;i++)
{
if(!vis[i])prime[++cnt]=i;
for(int j=1,x;j<=cnt&&(x=i*prime[j])<179424674;j++)
{
vis[x]=1;
if(!(i%prime[j]))break;
}
}
}
int main()
{
pre_work();
scanf("%d%d%d",&n,&k,&w);
for(long long i=1;i<=n;i++)S1[i]=prime[i]*i%w;
for(int i=1;i<=n;i++)S2[i]=S1[i]+S1[i/10+1];
for(int i=1;i<k;i++)t[S2[i]]++;
if(k&1)
{
int median=(k>>1)+1;
int lst=0;
int hand=-1;
for(int i=k;i<=n;i++)
{
t[S2[i]]++;
if(S2[i]<=hand)lst++;
if(i>k)
{
t[S2[i-k]]--;
if(S2[i-k]<=hand)lst--;
}
while(lst<median)lst+=t[++hand];
while(lst>=median+t[hand])lst-=t[hand--];
ans+=hand;
}
}
else
{
int median=(k>>1);
int lst1=0,lst2=0;
int hand1=-1,hand2=-1;
for(int i=k;i<=n;i++)
{
t[S2[i]]++;
if(S2[i]<=hand1)lst1++;
if(S2[i]<=hand2)lst2++;
if(i>k)
{
t[S2[i-k]]--;
if(S2[i-k]<=hand1)lst1--;
if(S2[i-k]<=hand2)lst2--;
}
while(lst1<median)lst1+=t[++hand1];
while(lst2<median+1)lst2+=t[++hand2];
while(lst1>=median+t[hand1])lst1-=t[hand1--];
while(lst2>=median+1+t[hand2])lst2-=t[hand2--];
ans+=(double)(hand1+hand2)/2;
}
}
printf("%.1lf",ans);
return 0;
}

rp++

[CSP-S模拟测试]:Median(暴力+模拟)的更多相关文章

  1. [CSP-S模拟测试]:跳房子(模拟)

    题目描述 跳房子,是一种世界性的儿童游戏,也是中国民间传统的体育游戏之一.跳房子是在$N$个格子上进行的,$CYJ$对游戏进行了改进,该成了跳棋盘,改进后的游戏是在一个$N$行$M$列的棋盘上进行,并 ...

  2. [CSP-S模拟测试]:Reverse(模拟+暴力+剪枝)

    题目描述 小$G$有一个长度为$n$的$01$串$T$,其中只有$T_S=1$,其余位置都是$0$.现在小$G$可以进行若干次以下操作: $\bullet$选择一个长度为K的连续子串($K$是给定的常 ...

  3. [考试反思]0719NOIP模拟测试6 + 0722NOIP模拟测试7

    连续爆炸,颇为愉快. 第6次:Rank #4 第7次:Rank #9 对于第6次考试,个人比较满意,因为T1只是差了一个卡常. 因为在考试前两天刚讲了矩阵,满脑子都是矩阵,还想到了循环矩阵优化. 整个 ...

  4. csp-s模拟测试112 & csp-s模拟测试113

    考前两天模拟. Day1直接炸飞,T1浪费的时间太长,对拍+调试了一个多小时但复杂度还不能过,最后5分钟想出来了解决方案但是已经打不出来了.T2读入出了事故RE0.T3打了假贪心. Day2心态几乎也 ...

  5. [CSP-S模拟测试]:666(模拟)

    题目描述 不忘初心. 小$\pi$假期在家无聊,打开了某弹幕直播网站. 突然,有一个精彩的镜头. 小$\pi$看到了满屏的$6$,其中,有$666$.也有$666666$.也有$6666666666. ...

  6. [CSP-S模拟测试]:砖块(模拟)

    题目描述 在一个二维网格平面上,一个网格的坐标由其左下角的点的坐标定义$(x,y)$.在一个二维网格平面上,一个网格的坐标由其左下角的个点的坐标定义$(0,0)$的区域中,此时存在高度为$k$的初始砖 ...

  7. [CSP-S模拟测试]:五子棋(模拟)

    题目传送门(内部题122) 输入格式 输入文件第一行为一个正整数$n$,表示双方总共下了多少步棋. 接下来$n$行,输入文件每行两个正整数.第$i$行的两个数$x,y$表示第$i$步的棋子下在了第$x ...

  8. [CSP-S模拟测试]:线性代数(模拟)

    题目传送门(内部题113) 输入格式 第一行一个正整数$n$. 接下来$n$行,每行$n$个整数,描述$C$矩阵.保证输入的是一个林先森矩阵. 输出格式 若不可能实现,则输出一行$Impossible ...

  9. [CSP-S模拟测试]:集合论(模拟)

    题目传送门(内部题73) 输入格式 输入文件$jihe.in$ 第一行一个整数$m$,表示操作的次数. 接下来$m$行,每行描述一个操作. 每行的开始都是一个数字,$1,2,3,4$依次代表$unio ...

随机推荐

  1. sqoop应用

    1.导入数据(将mysql(rdbms)的表的数据导入到hdfs) 1.1.全部导入(注意空格) sqoop import \ --connect jdbc:mysql://192.168.159.1 ...

  2. 阅读jdk源码的流程(从今天开始要阅读jdk源码)

    1.java.lang 2.java.util 3.java.util.concurrent 4.java.util.concurrent.atomic 5.java.lang.reflect 6.j ...

  3. Mac012--FinalShell SSH工具

    Mac--FinalShell SSH工具 FinalShell SSH工具,服务器管理,远程桌面加速软件,支持Windows,Mac OS X,Linux FinalShell,国货产品,同类产品有 ...

  4. VS2008 项目启动时报:“无法直接启动带有类库输出类型的项目”

    解决办法一: 右击要解决方案项目--属性-通用属性—单启动项目 解决方法二:直接选中界面类,右击设为启动项目, 如果还是这样,那么在此项目上按右键 (VS2010的资源管理工具中),点属性,更改设置.

  5. web 前端1 html5基础

    HTML web sockent 实例 import socket def handle_request(client): buf = client.recv(1024) client.sendall ...

  6. (136)leetcode刷题Python笔记——只出现一次的数字

    题目如下: 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用额外空间来实现吗? 示例 1: ...

  7. Spark-Core RDD的创建

    一.RDD创建的3种方式: 1.从集合中创建RDD 2.从外部存储创建RDD 3.从其他RDD转换得到新的RDD 二.从集合中创建RDD 1.使用parallelize函数创建 scala> v ...

  8. 通过总线机制实现自动刷新客户端配置(Consul,Spring Cloud Config,Spring Cloud Bus)

    通过总线机制实现自动刷新客户端配置 方案示意图 利用Git服务的webhook通知功能,在每次更新配置之后,Git服务器会用POST方式调用配置中心的/actuator/bus-refresh接口,配 ...

  9. P5445 [APIO2019]路灯

    传送门· 对于询问 $(a,b)$ ,感觉一维很不好维护,考虑把询问看成平面上的一个点,坐标为 $(a,b)$ 每个坐标 $(x,y)$ 的值表示到当前 $x$ 和 $y$ 联通的时间和 考虑一个修改 ...

  10. python实现不同条件下单据体的颜色不一样,比如直接成本分析表中关闭的细目显示为黄色

    #引入clr运行库 import clr #添加对cloud插件开发的常用组件的引用 clr.AddReference('Kingdee.BOS') clr.AddReference('Kingdee ...