[BZOJ2956]模积和-根号分块

2024-01-21 01:10
文章标签 根号 分块 bzoj2956 模积

本文主要是介绍[BZOJ2956]模积和-根号分块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

说在前面

突然觉得”说在前面”里的废话真是太多了= =


题目

BZOJ2956传送门

题目大意

给定 N ,M,求出 i=1Nj=1M(Nmodi)(Mmodj)[i!=j] 在模19940417意义下的值。 n,m109

输入输出格式

输入格式:
输入一行两个整数 N M,含义如题

输出格式:
输出一行一个整数,表示答案


解法

直接化简式子,把题目中 ij 的拆成 i,j 的答案减去 i=j 的答案。
对于 i,j 有:
i=1Nj=1M(Nmodi)(Mmodj)
=i=1Nj=1M(Nnii)(MMjj)
=i=1Nj=1M(NMNMjjMNii+ijNiMj)
=N2M2N2j=1MMjjM2i=1nNii+i=1NiNij=1MjMj

对于 i=j 的情况类似,可以自行推导=w=
(其实是懒得写….Latex太麻烦了,下面这张图就是上面那一串的源码,mmp)
这里写图片描述


自带大常数的代码

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std ;const int mmod = 19940417 , inv6 = 3323403 ;
long long N , M ;long long ds( long long lf , long long rg ){return ( lf + rg ) * ( rg - lf + 1 ) / 2 %mmod ;
}long long pfs( long long lf , long long rg ){lf = lf - 1 ;long long tmp1 = rg * ( rg + 1 )%mmod * ( 2 * rg + 1 ) %mmod * inv6 %mmod ,tmp2 = lf * ( lf + 1 )%mmod * ( 2 * lf + 1 ) %mmod * inv6 %mmod ;return ( tmp1 - tmp2 + mmod )%mmod ;
}long long cal( long long a , long long lim , long long div ){long long rt = 0 ;for( int i = 1 , last = 1 ; i <= lim ; i = last ){int ed = min( div / ( div / i ) , lim ) ;rt = ( rt + ( div / i ) * ds( last , ed ) ) %mmod ;last = ed + 1 ;}return rt * a %mmod ;
}long long spe(){long long rt = 0 ;for( int i = 1 , last = 1 ; i <= M ; i = last ){int ed = min( M / ( M / i ) , N / ( N / i ) ) ;rt = ( rt + ( M / i ) * ( N / i )%mmod * pfs( last , ed )%mmod )%mmod ;last = ed + 1 ;}return rt ;
}int main(){long long ans1 = 0 , ans2 = 0 ;scanf( "%lld%lld" , &N , &M ) ;if( N < M ) swap( N , M ) ;ans1 = N * N%mmod * M%mmod * M%mmod - cal( N*N%mmod , M , M ) - cal( M*M%mmod , N , N ) + cal( 1 , N , N ) * cal( 1 , M , M ) %mmod ;ans1 = ( ans1%mmod + mmod )%mmod ;ans2 = N * M%mmod * M%mmod - cal( N%mmod , M , M ) - cal( M%mmod , M , N ) + spe() ;ans2 = ( ans2%mmod + mmod )%mmod ;printf( "%lld" , ( ans1 - ans2 + mmod )%mmod ) ;
}

这篇关于[BZOJ2956]模积和-根号分块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/627936

相关文章

Spring Boot实现大文件分块上传

1.分块上传使用场景 大文件加速上传:当文件大小超过100MB时,使用分片上传可实现并行上传多个Part以加快上传速度。 网络环境较差:网络环境较差时,建议使用分片上传。当出现上传失败的时候,您仅需重传失败的Part。 文件大小不确定: 可以在需要上传的文件大小还不确定的情况下开始上传,这种场景在视频监控等行业应用中比较常见。 2.实现原理 实现原理其实很简单,核心就是客户端把大文件

【BNU】40719 Arithmetic Progressions【分块+FFT】

传送门:【BNU】40719 Arithmetic Progressions 题目分析: 用分块+FFT强行AC了这题…… 之前一直TLE……然后改了好久把姿势改的优美点了……终于过了…… 大概思路是:我们考虑分块,假设每一块的大小为S,一共分了B块然后我们分两种情况讨论: 1.第二个数在第i块,第一个数在(1~i-1)块内,第三个数在(i+1~B)块内。 2.至少两个数在同一块内。

【HDU】5213 Lucky 【分块(在线算法)】

传送门:【HDU】5213 Lucky 题目分析: 我来说一下这题的在线做法。 首先我们将区间分成 n√ \sqrt n块,用f[x][y]表示第x块的数和第y块的数相加等于K的对数,这个可以 O(nn√) O(n \sqrt n)的预处理。然后还有g[x][y]表示在第1~x块中有的大小为y的数的个数,这个的复杂度同样 O(nn√) O(n \sqrt n)。 接下来,对于每组询问,我们

针对大数据的种子点生长——分块生长的策略

前言   在之前的种子点生长系列中,探讨了使用三种提取图像中内容部分种子点生长算法,分别是泛洪法、扫描线法和区段法。我们知道这三种算法在空间上都需要占用三维图像的空间以及相应的位图标记表的空间。有时,我们需要处理一些体积相当大的数据,这些数据都是内存中无法放下的,如数十数百GB的数据,想要获得其中图像内容信息,一般需要对图像进行分块生长。   本文使用一种比较直接的思路对数据进行分块,然

P3313 [SDOI2014] 旅行(分块做法)

~~~~~      P3313 [SDOI2014] 旅行 ~~~~~      总题单链接 思路 ~~~~~      遇到这种树上路径问题,就考虑用重链剖分转为区间问题。 ~~~~~      问题转换为了:给定一个区间和 k k k,求这个区间内信仰为 k k k 的城市的 权值和 或 最大权值。 ~~~~~      这个问题也可以用动态开点线段树解决(现在不会,以后

学习笔记 ---- 数论分块(整除分块)

文章目录 算法概述引理引理 1 1 1引理 2 2 2 数论分块结论(区间右端点公式)过程 N N N 维数论分块向上取整的数论分块 例题 H ( n ) H(n) H(n)[CQOI2007] 余数求和[清华集训2012] 模积和 算法 概述 数论分块可以快速计算一些含有除法向下取整的和式(即形如 ∑ i = 1 n f ( i ) g ( ⌊ n i ⌋ ) \sum

C/C++网络编程--文件分块传输

文件分块传输是网络编程中一个常见的任务,尤其是在处理大文件时,将文件分块可以提高传输效率,简化错误处理,并可以实现并发传输。下面,写个从客户端向服务器发送大型数据的demo。 客户端 客户端有两点需要注意,在传输分两个一个是文件总块数和文件块,。传输文件总块数让服务器知道有多少文件块需要接收,确保所有数据都被完整地发送到服务器,避免因文件块数不对导致文件重组失败。 传输文件总块数 int

初学HTML用法大全指导(五)html建立网页中的表单与DIV、SPAN分块

上一篇博客我们讲了html脚本语言中超链接的创建与使用,这一篇博客我们来聊一聊web网页中常用的表单的建立,我们在登录一个新的网站时想成为这个网站的VIP会员或者普通用户时常常面临着各种信息的登记,以及在登录这个系统时要输入自己的账户和密码,比如CSDN中,我们想登录进入自己的账户时,就要输入账户和密码。这是HTML脚本语言中的表单操作就称为了很重要的作用。最常见的表单标签有:文本框

大文件分块上传和续传

给出一个Spring Boot项目中完成大文件分块上传和续传功能的完整示例代码解释,下面的示例将集中展示前端与后端的交互过程,将分别从客户端(前端)以及服务器端(后端)实现的角度来看实现思路。 定前端使用了axios进行与后端的交互,后端则利用Spring Boot来响应前端的请求和处理文件。 客户端(前端)实现 客户端的实现主要是利用axios或任何HTTP库,如fetch,来分块上传文件

Laravel 大数据量分块处理

User::where(‘status’, 0)->select(array(‘fild1’,‘fild2’)) ->chunkById(100, function ($reslut) { var_dum($reslut); },‘查询排序id’);