[luogu7116]微信步数
先判定无解,当且仅当存在一个位置使得移动$n$步后没有结束且仍在原地
暴力枚举移动的步数,记$S_{i}$为移动$i$步(后)未离开范围的点个数,则恰好移动$i$步的人数为$S_{i-1}-S_{i}$(特别的$S_{0}=P$),答案即为$\sum_{i=1}^{D}(S_{i-1}-S_{i})i=\sum_{i=0}^{D-1}S_{i}$(其中$D=\min_{S_{i}=0}i$)
考虑如何求出$S_{i}$,记$len_{j}$为第$j$维的合法范围,由于每一维互不干扰,则有$S_{i}=\prod_{j=1}^{m}len_{j}$
由于每$n$步必然重复向一个方向移动,那么$D\le n\max w_{i}$,总复杂度即$o(nm\max w_{i})$
进一步优化,将$S_{i}$按$i\ mod\ n$的值分组,对于第$i$组($i\in [0,n)$),$i$单独计算,然后求出$i+n$时的$len_{j}$,记$n$步的总位移为$d_{i}$,则第$kn+i(k\ge 1)$步时$len'_{j}=\max(len_{j}-(k-1)|d_{j}|,0)$
写成式子,即$\sum_{k=1}^{D'}\prod_{j=1}^{m}(len_{j}+|d_{j}|-k|d_{j}|)$(其中$D'=\min_{j=1}^{m}\frac{len_{j}}{|d_{j}|}$,因为$\max$取0后一定为0,不需要再计算)
将后式$o(m^{2})$暴力展开,那么就是一个关于$k$的一个$m+1$次多项式,多项式的前缀和也可以$o(m^{2})$计算,总复杂度即为$o(nm^{2})$
1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 500005
4 #define M 20
5 #define mod 1000000007
6 int n,m,ans,w[M],x[N],y[N],d[M],mx[N<<1][M],mn[N<<1][M],g[M],sum[M][M];
7 int ksm(int n,int m){
8 if (!m)return 1;
9 int s=ksm(n,m>>1);
10 s=1LL*s*s%mod;
11 if (m&1)s=1LL*s*n%mod;
12 return s;
13 }
14 int mul(int x,int y){
15 for(int i=m+1;i;i--)g[i]=(1LL*g[i-1]*x+1LL*g[i]*y)%mod;
16 g[0]=1LL*g[0]*y%mod;
17 }
18 int calc(int k,int x){
19 int s=1,ans=0;
20 for(int i=0;i<=k+1;i++){
21 ans=(ans+1LL*s*sum[k][i])%mod;
22 s=1LL*s*x%mod;
23 }
24 return ans;
25 }
26 int main(){
27 scanf("%d%d",&n,&m);
28 sum[0][1]=1;
29 for(int i=1;i<=m;i++){//i+1次多项式,
30 int y=0;
31 for(int x=0;x<=i+1;x++){
32 y=(y+ksm(x,i))%mod;
33 memset(g,0,sizeof(g));
34 g[0]=y;
35 for(int j=0;j<=i+1;j++)
36 if (j!=x){
37 mul(1,mod-j);
38 mul(0,ksm((x-j+mod)%mod,mod-2));
39 }
40 for(int j=0;j<=i+1;j++)sum[i][j]=(sum[i][j]+g[j])%mod;
41 }
42 }
43 for(int i=1;i<=m;i++)scanf("%d",&w[i]);
44 for(int i=1;i<=n;i++){
45 scanf("%d%d",&x[i],&y[i]);
46 d[x[i]]+=y[i];
47 for(int j=1;j<=m;j++){
48 mx[i][j]=max(mx[i-1][j],d[j]);
49 mn[i][j]=min(mn[i-1][j],d[j]);
50 }
51 }
52 for(int i=n+1;i<=2*n;i++){
53 d[x[i-n]]+=y[i-n];
54 for(int j=1;j<=m;j++){
55 mx[i][j]=max(mx[i-1][j],d[j]);
56 mn[i][j]=min(mn[i-1][j],d[j]);
57 }
58 }
59 for(int i=1;i<=m;i++)d[i]/=2;
60 bool flag1=0,flag2=0;
61 for(int i=1;i<=m;i++)
62 if (d[i])flag1=1;
63 for(int i=1;i<=m;i++)
64 if (mx[n][i]-mn[n][i]>w[i])flag2=1;
65 //flag1说明离开了原位置,flag2说明一定是一轮
66 if ((!flag1)&&(!flag2)){
67 printf("-1");
68 return 0;
69 }
70 for(int i=0;i<n;i++){
71 int s=1;
72 for(int j=1;j<=m;j++)s=1LL*s*max(w[j]-(mx[i][j]-mn[i][j]),0)%mod;
73 ans=(ans+s)%mod;
74 }
75 for(int i=n;i<2*n;i++){
76 bool flag=0;
77 for(int j=1;j<=m;j++)
78 if (w[j]-(mx[i][j]-mn[i][j])<0)flag=1;
79 if (flag)break;
80 memset(g,0,sizeof(g));
81 g[0]=1;
82 for(int j=1;j<=m;j++)mul(mod-abs(d[j]),w[j]-(mx[i][j]-mn[i][j])+abs(d[j]));
83 int D=0x3f3f3f3f;
84 for(int j=1;j<=m;j++)
85 if (d[j])D=min(D,(w[j]-(mx[i][j]-mn[i][j]))/abs(d[j])+1);
86 for(int j=0;j<=m;j++)ans=(ans+1LL*g[j]*calc(j,D))%mod;
87 }
88 printf("%d",ans);
89 }
[luogu7116]微信步数的更多相关文章
- 【Redis面试题】如何使用Redis实现微信步数排行榜?
1. 前言 之前写过一篇博客,讲解的是Redis的5种数据结构及其常用命令,当时有读者评论,说希望了解下这5种数据结构各自的使用场景,不过一直也没来得及写. 碰巧,在3月份找工作面试时,有个面试官先问 ...
- 「NOIP 2020」微信步数(计数)
「NOIP 2020」微信步数(Luogu P7116) 题意: 有一个 \(k\) 维场地,第 \(i\) 维宽为 \(w_i\),即第 \(i\) 维的合法坐标为 \(1, 2, \cdots, ...
- [NOIP 2020] 微信步数
一.题目 点此看题 二.题目 首先感谢一下这位大佬的博客,虽然我看不懂您的讲解,但是还是读得懂代码的 思路是 \(\tt jys\) 给我讲明白的,首先我们可以感觉到快速计算它肯定和矩形有关系,也就是 ...
- 洛谷 P7116 - [NOIP2020] 微信步数(拉格朗日插值)
洛谷题面传送门 我竟然独立切掉了这道题!incredible! 纪念我逝去的一上午(NOIP 总时长 4.5h,这题做了我整整 4.5h) 首先讲一下现场我想的 80 分的做法,虽然最后挂成了 65 ...
- pyechart基本使用大全
charts_base 原文链接:https://blog.csdn.net/weixin_43735353/article/details/89328048 图表详细配置请参考 图表配置篇 基本图表 ...
- 小白学Python(17)——pyecharts 日历图 Calendar
Calendar-2017年微信步数情况 import datetime import random from pyecharts import options as opts from pyecha ...
- .Net Core2.*学习手册
1.net core 基础知识解析(创建一个.net core网站)(视频录制) 1.1 Startup解析(没写) 1.2 目录结构分析(没写) 1.3 使用静态文件(没写) 1.4 Control ...
- 最新Pyecharts-基本图表
Pyecharts是由Echarts而来,Echarts是百度开源的数据可视化的库,适合用来做图表设计开发,当使用Python与Echarts结合时就产生了Pyecharts.可使用pip安装,默认是 ...
- 【Python可视化】超详细Pyecharts 1.x教程,让你的图表动起来~
前言 pyecharts 是一个用于生成 Echarts 图表的Python库.Echarts是百度开源的一个数据可视化 JS 库,可以生成一些非常酷炫的图表. Pyecharts在1.x版本之后迎来 ...
随机推荐
- bzoj2038 小z的袜子 (莫队)
题目大意 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命-- 具体来说,小Z把这N只袜子从1到N编 ...
- 学习笔记——不带修序列莫队 (luogu2079)小B的询问
莫队是一种对于询问的离线算法 时间复杂度:O(\(n \sqrt n\)) 大致思想就是 首先将询问离线,然后对原序列分块,使得每一个\(l和r\)都在一个块里 然后按照左节点排序,若所在的块相等,就 ...
- 一个简单的Java应用程序
目录 一个简单的Java应用程序 首次运行结果 程序示例 运行结果 修改大小写之后的运行结果 程序示例 运行结果 关键字public 关键字class 类名及其命名规则 类名必须以字母开头 不能使用J ...
- 详解python三大器——迭代器、生成器、装饰器
迭代器 聊迭代器前我们要先清楚迭代的概念:通常来讲从一个对象中依次取出数据,这个过程叫做遍历,这个手段称为迭代(重复执行某一段代码块,并将每一次迭代得到的结果作为下一次迭代的初始值). 可迭代对象(i ...
- python OptionParser的用法
from optparse import OptionParser parser = OptionParser(usage = "usage: %prog [options] arg&quo ...
- Java 读取PDF中的表格
一.概述 本文以Java示例展示读取PDF中的表格的方法.这里导入Spire.PDF for Javah中的jar包,并使用其提供的相关及方法来实现获取表格中的文本内容.下表中整理了本次代码使用到的主 ...
- ORA-19815: WARNING: db_recovery_file_dest_size闪回区爆满问题处理
问题描述:有一个数据库起不来了,根据层层排查,是因为归档设置在了闪回区,文件的大小已经超出了闪回区限制.最后直接给数据库拖挂 环境:windows server2012 , oracle 19c,单机 ...
- Java Filter型内存马的学习与实践
完全参考:https://www.cnblogs.com/nice0e3/p/14622879.html 这篇笔记,来源逗神的指点,让我去了解了内存马,这篇笔记记录的是filter类型的内存马 内存马 ...
- springcloud(二) 微服务架构编码构建
微服务架构编码构建 1 基础知识 1.1 版本 2 微服务cloud整体聚合父工程Project 2.1 new project 2.2 字符编码设置 utf-8 2.3 pom.xml 2.4 父工 ...
- 新型活跃Mozi样本分析报告
基本信息 对象 值 文件名 Photo.scr 文件类型 PE32 executable for MS Windows (GUI) Intel 80386 32-bit 文件大小 6271259 by ...