话说小X在孩提时,都会做标准的蛇形矩阵了,发现很好玩。现在的小X很想对其进行改版,变为如下类型的一个无限大蛇形数阵:

令S(x)表示以1为左上角,x为右下角的矩形内所有数之和。例如S(12)就是具有深色背景的数之和。
给定n,对于“以1为左上角,n为右下角的矩形”内的每一个数i,计算所有S(i)之和。例如,当n=8时,所求结果为S(1)+S(2)+S(9)+S(4)+S(3)+S(8)=1+3+12
+5+10+27=58。

输入格式:

输入文件仅包含一个整数n

输出格式:

输出所求结果除以1,000,000,007的余数。。

样例输入:

12

样例输出:

282

数据范围:

对于20%的数据满足1<=n<=102;
对于40%的数据满足1<=n<=5000;
对于60%的数据满足1<=n<=106;
对于100%的数据满足1<=n<=1010。

时间限制:

1s

空间限制:

256m

 

数论

这道题O(n)的算法是很好想的,只要模拟n次,将数字为n的坐标和矩阵中每个数和位置处理出来

然后可以发现对于矩阵来说,每个数被累加到的次数为这一点到矩阵右下角的子矩阵大小

即$ans=\sum_{i}\sum_{j}a_{i,j}*(x-i+1)*(y-j+1)$

比如12的矩阵中,8被累加的次数为4次

那么就可以统计答案了

但O(n)的算法不足以解决这道题

可以发现可以在O(1)的时间内处理出一个数的位置

那么可以将这个矩阵划分成一个在这个矩阵中最大的正方形和若干条宽度为一的矩形

一个正方形也可以划分成几个“7”字型,那么对于这个"7"字形和宽度为一的矩形可以O(1)的处理出答案

那么总复杂度为$O(\sqrt{n})$

那么“7”字形公式推导过程如下

此处仅以奇数的正方形的"7"为例

设当前为第$i$个正方形,整个矩阵的右下角为$(x,y)$

右上的数为$i^{2}$坐标$(i,i)$,左下的数为$(i-1)^{2}+1$,坐标$(i,1)$,中间拐点处为右上和左下数的平均数,坐标$(i,i)$

那么将这个"7"切成一条竖的和一条横着边

如9所在的"7"字形,将其切成7-9和5-7两个边

那么下条边答案为

$((i-1)^{2}+1)*(x-i+1)*y+((i-1)^{2}+1+1)*(x-i+1)*(y-1)+...+((i-1)^{2}+1+i-1)*(x-i+1)*(y-i+1)$

设$s=(i-1)^{2}+1$

$s*(x-i+1)*y+(s+1)*(x-i+1)*(y-1)+...+(s+i-1)*(x-i+1)*(y-i+1)$

$(x-i+1)*[s*y+(s+1)*(y-1)+...+(s+i-1)*(y-i+1)]$

$(x-i+1)*[i*s*y+\sum_{j=1}^{i-1}(y-s)-\sum_{k=1}^{i-1}k^{2}]$

$(x-i+1)*[i*s*y+\frac{i*(i-1)}{2}(y-s)-\frac{i*(i-1)*(2*i-1)}{6}]$

即为公式,那么上条边同理

$(y-i+1)*[i*s*x-\frac{i*(i-1)}{2}(x+s)+\frac{i*(i-1)*(2*i-1)}{6}]$

$s=i^{2}$

因为统计了中间拐点的答案两次

最后再减去中间拐点的答案即可

其他同理,可以推出相同形式的公式

#include <bits/stdc++.h>
#define ll long long
#define mod (ll)1000000007
using namespace std;
ll n,m,ans;
ll findx(ll num)
{
ll s;
s=(ll)sqrt(num);
if (s*s==num)
{
if (s&1)
return 1;
else
return s;
}
ll mid;
s++;
mid=((s-1)*(s-1)+1+s*s)>>1;
if (num>=mid)
{
if (s&1)
return s-(num-mid);
else
return s;
}
else
{
if (s&1)
return s;
else
return s-(mid-num);
}
}
ll findy(ll num)
{
ll s;
s=(ll)sqrt(num);
if (s*s==num)
{
if (s&1)
return s;
else
return 1;
}
ll mid;
s++;
mid=((s-1)*(s-1)+1+s*s)>>1;
if (num>=mid)
{
if (s&1)
return s;
else
return s-(num-mid);
}
else
{
if (s&1)
return s-(mid-num);
else
return s;
}
}//O(1)的时间处理出坐标
int main()
{
scanf("%lld",&n);
ll x,y;
x=findx(n);y=findy(n);
m=min(x,y);
for (ll i=m;i>=1;i--)
{
ll mid;
mid=((i-1)*(i-1)+1+i*i)>>1;
if (i&1)
{
ll s;
s=i*i;
s%=mod;
ans=ans+(i*x%mod*s%mod+i*(i-1)*(2*i-1)/6-i*(i-1)/2*(s+x)%mod+mod)%mod*(y-i+1)%mod;
ans%=mod;
s=i*i-2*i+2;
s%=mod;
ans=ans+(i*s%mod*y%mod-i*(i-1)*(2*i-1)/6+i*(i-1)/2*(y-s)%mod+mod)%mod*(x-i+1)%mod;
ans%=mod;
ans=(ans-mid*(x-i+1)%mod*(y-i+1)%mod+mod)%mod;
}
else
{
ll s;
s=i*i-2*i+2;
s%=mod;
ans=ans+(i*s%mod*x%mod-i*(i-1)*(2*i-1)/6+i*(i-1)/2*(x-s)%mod+mod)%mod*(y-i+1)%mod;
ans%=mod;
s=i*i;
s%=mod;
ans=ans+(i*y%mod*s%mod+i*(i-1)*(2*i-1)/6-i*(i-1)/2*(s+y)%mod+mod)%mod*(x-i+1)%mod;
ans%=mod;
ans=(ans-mid*(x-i+1)%mod*(y-i+1)%mod+mod)%mod;//减去中间拐点的值
}
ans=(ans+mod)%mod;
}
for (ll i=m+1;i<=y;i++)
{
if (i&1)
{
ll s;
s=i*i;
s%=mod;
ans=ans+(x*x%mod*s%mod+x*(x-1)*(2*x-1)/6-x*(x-1)/2*(s+x)%mod+mod)%mod*(y-i+1)%mod;
ans%=mod;
}
else
{
ll s;
s=i*i-2*i+2;
s%=mod;
ans=ans+(x*s%mod*x%mod-x*(x-1)*(2*x-1)/6+x*(x-1)/2*(x-s)%mod+mod)%mod*(y-i+1)%mod;
ans%=mod;
}
ans=(ans+mod)%mod;
}
for (ll i=m+1;i<=x;i++)
{
if (i&1)
{
ll s;
s=(i*i-2*i+2);
s%=mod;
ans=ans+(y*s%mod*y%mod-y*(y-1)*(2*y-1)/6+y*(y-1)/2*(y-s)%mod+mod)%mod*(x-i+1)%mod;
ans%=mod;
}
else
{
ll s;
s=i*i;
s%=mod;
ans=ans+(y*y%mod*s%mod+y*(y-1)*(2*y-1)/6-y*(y-1)/2*(s+y)%mod+mod)%mod*(x-i+1)%mod;
ans%=mod;
}
ans=(ans+mod)%mod;
}
printf("%lld\n",(ans+mod)%mod);
}

XJOI 夏令营501-511NOIP训练17 蛇形数阵的更多相关文章

  1. 夏令营501-511NOIP训练17——蛇形矩阵

    传送门:QAQQAQ 题意:话说小X在孩提时,都会做标准的蛇形矩阵了,发现很好玩.现在的小X很想对其进行改版,变为如下类型的一个无限大蛇形数阵:令S(x)表示以1为左上角,x为右下角的矩形内所有数之和 ...

  2. XJOI夏令营501训练1——分配工作

    传送门:QAQQAQ 题意:某公司有工作人员x1,x2,…,xn ,他们去做工作y1,y2,…,ym(n<=m) ,每个人都能做其中的几项工作,并且对每一项工作都有一个固定的效率.问能否找到一种 ...

  3. 算法训练 K好数

      算法训练 K好数   时间限制:1.0s   内存限制:256.0MB 问题描述 如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数.求L位K进制数中K好数 ...

  4. 算法训练 K好数 解析

    算法训练 K好数 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 问题描述 如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数.求L位K ...

  5. ZROI1153 【线上训练3】数个数

    ZROI1153 [线上训练3]数个数 传送门 一道非常有意思的题,涵盖了各种知识点. 首先,很显然,这是个容斥.容斥可以过掉\(30pts\). 这里我们考虑容斥+DP. 我们令\(dp[i][j] ...

  6. Java实现 蓝桥杯 算法训练 K好数

    算法训练 K好数 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 问题描述 如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数.求L位K ...

  7. Java实现 蓝桥杯VIP 算法训练 麦森数

    算法训练 麦森数 时间限制:1.0s 内存限制:256.0MB 问题描述 形如2P-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2P-1不一定也是素数.到1998年底, ...

  8. XJOI 夏令营501-511NOIP训练18 高二学堂

    在美丽的中山纪念中学中,有座高二学堂,同样也是因为一个人,让它们变 成了现在这个样子~那就是我们伟大的级主任.因为他,我们又迎来了一个木有电影,只有对答案的段考日:又迎来了一个不是大礼拜,而是小礼拜的 ...

  9. XJOI 夏令营501-511NOIP训练18 高三楼

    参观完各种饭堂,学校还有什么著名的景点呢?当然是教室了,此时此刻我 们来到了高三楼.你会发现高三楼门口会有以身份认证系统,这东西还有着一段疼人的历史.每年的九月到来,高三的童鞋大多不习惯学校的作息时间 ...

随机推荐

  1. 01 How does C Programming work ? C语言如何工作?

    where is C used ? C 语言的应用场景 C is widely used C语言被广泛应用于: For creating desktop applications 用于创建桌面应用程序 ...

  2. C++指针delete后还要置为null

    非常好的一篇说明: 转载:https://blog.csdn.net/qq_36570733/article/details/80043321 众所周知,最开始我们用new来创建一个指针,那么等我们用 ...

  3. C语言编程入门之--第六章C语言控制语句

    导读:本章带读者理解什么是控制语句,然后逐个讲解C语言常用的控制语句,含有控制语句的代码量多起来后就要注意写代码的风格了,本章末节都是练习题,大量的练习才能掌握好控制语句的使用. 6.1 什么是控制语 ...

  4. 远程触发Jenkins的Pipeline任务

    场景 虽然能配置提交代码时触发Jenkins任务,但有时并不需要每次提交代码都触发,而是仅在有需要时才执行. 除了在Jenkins页面上手动执行任务,还可以向Jenkins网站发起HTTP请求,触发指 ...

  5. Golang是如何操作excel的?

    关键术语介绍 为了方便开源库的快速上手,我们先来了解 excel 中的几个关键术语,如下图所示,①为sheet,也就是表格中的页签:②为row,代表 excel 中的一行:③为cell,代表 exce ...

  6. 第3天 | 12天搞定Python,用VSCode编写代码

    Visual Studio Code (简称 VS Code), 是一款免费并且开源的现代化轻量级代码编辑器,支持语法高亮.智能代码补全.自定义热键.括号匹配.代码片段等特性,并针对网页开发做了优化. ...

  7. Jetson AGX Xavier部署ORB_SLAM2(ROS)

    1. 修改CMakeLists.txt Examples/ROS/ORB_SLAM2下的CMakeLists.txt 原 set(LIBS ${OpenCV_LIBS} ${EIGEN3_LIBS} ...

  8. idea创建servlet工程初体验

    servlet工程创建 前提:创建项目之前需要配置java环境变量 和tomcat配置,配置完成后进入如下操作. tomcat 安装和配置参考 https://www.cnblogs.com/xush ...

  9. centos平台scp通过密钥远程复制文件(免密登录)

    一,说明:两台机器的平台和ip 1,a服务器: centos8:ip:121.122.123.47 版本 [root@yjweb ~]# cat /etc/redhat-release CentOS ...

  10. 2020主流国产BI产品对比

    国产BI软件由于具备较强的本土特性,可以很好地适应国内用户的使用习惯,越来越多被国内用户使用.目前国内BI产品很多,可谓百家争鸣,如何从众多的BI产品中选择适合自己的呢?这里我们对比一下目前国内主流的 ...