·题目:

        西施与范蠡泛舟而去……不对,场景不对,咳咳。在甄嬛前往蓬莱洲之前,她与皇上在碧桐书院告别。为了这可能会长达数月的离别,两个人都似乎有很多话要对对方说,却都无语凝噎。这时,皇上突然发话:“嬛嬛啊(桓桓?),既然你我都说不出话来,那这时间也不好打发,我们来数三角形吧。”为了满足皇上突发而来的童趣,甄嬛欣然陪同了。可这……纸上是一张n*m的格子方阵,即有(n+1)*(m+1)个格点。每个格子都是边长为1的正方形。而他们要数的,则是任取3个格点作为三角形的顶点所形成的直角三角形且该三角形面积为s/2的个数。甄嬛数的头都晕了,她现在只想知道满足条件的三角形个数 mod 1000000007。

输入格式:第一行3个正整数n,m,s, 意义如题
输出格式:仅一个整数,为甄嬛与满足条件的三角形个数 mod (10^9+7)
样例输入:1 1 1
样例输出:4
数据范围:
对于10%的数据:n<=10
对于另外40%的数据:s为质数
对于100%的数据:1<=n,m,s<=108
时间限制: 1S
空间限制: 128M

·题目混乱,述大意:

     给定长度为n*m的相同正方形方格组成的棋盘,求出使用格点组成的三角形个数,答案取模1000000007。(n,m<=108)。

·分析:

      在草稿纸上画图时容易发现一些普遍规律和特例,此时大米饼认为应该先里找出总体的方法,再进行特例的处理(如去重),这样很美妙。一个非常简单的思路是,设这个三角形的边长为a,b,那么在棋盘上就有如下摆法:

    

     同时要算上棋盘旋转90o后的情况,不要忘记一个三角形可以在同一个长方形里有四种摆法,所以对于这个形状的三角形的个数P可以表示为:

     P=(n-a+1)*(m-b+1)*4+(n-b+1)*(m-a+1)*4

     读题一会儿后意识到一个问题是三角形的边可以是斜着的。上文的天真方法连正确答案都无法得出:

     在经历初中数学洗礼的我们开始回想起中考时的一些琐碎,发现好像很多几何题都是这样子的——有关相似直角三角形。清晰地发现,这些三角形的直角边无非是由两个相似的直角三角形的斜边组成:

     依照这个思路,做一些便于代码书写的分析。首先使用a,b表示出橙色三角形的面积S=(a2+b2)*k[注意,k不一定偏要为整数,想一想,不为什么]。我们看一看数据范围:n,m<=100000000,开方后为10000,说明最坏情况循环下循环次数:108。不过,这里我们需要保证a,b,ak,bk均为整数,也就是分解数——“与分解有关的时间复杂度稳定性很差”,我们可以直接暴力枚举a,b,找到所有满足面积公式条件的二元组(a,b),并由此可以推出对应的k值。

     与此同时,一个更加振奋人心的消息——上文那种边与格子平行的情况可以看做(a,b)其中一个为0的情况,所以我们争取一起处理。

     这样看来,似乎只需要进行一个二重循环枚举a,b然后使用类似于上文的天真方法计算答案就可以了。在激动之余,你发现还有一些特殊情况。

     为了有序性和避免重复,我们规定枚举二元组(a,b)必须满足k的值大于等于1。我们先列出一般情况的答案计算方法。对于一组(a,b)构成面积为S的三角形的个数P计算方法:
    

    对于这个三角形,我们只需要求出其所在的最小矩形的长宽就可以了。由于a,b的大小关系不确定。所以:

     宽长度为:max(a,bk),长长度为:b+ak

   我们设长宽分别为p,q,那么S的个数为:

     P=(n-p+1)*(m-q+1)*4+(n-p+1)*(m-q+1)*4

    最后我们着眼于两种特殊情况的处理:

   [1] k==1:

      由于a,b大小不定,所以如果(a,b)满足,那么(b,a)也是合法的,此时相当于计算了8次,但是我们发现,由于k值为1,所以相似三角形为等腰,重复计算了,所以处理方式是除以二。

   [2] a==0||b==0:

     这表明是一个直角边和格子边平行的直角三角形。设u>0,如果二元组(u,0)合法,那么(0,u)同样合法,但是!(u,0),(0,u)形成的三角形形状完全相同,而(u,v),(v,u)[v>0]形成的三角形形状是相同或者不同,但是相同的情况被[1]的处理方式而排除,可是(u,0)(0,u)的重复计算没有排除。随意处理方式也是除以二。

     考试结束后其实很多STD的写法是将(a,b)中是否有0进行分开计算,这样更容易理解。但是追求更深刻理解和短码的大米饼毫不犹豫地视作一种情况讨论。代码来啦:

 #include<stdio.h>
#include<algorithm>
#define ll long long
#define M 1000000007
#define go(i,a,b) for(ll i=a;i<=b;i++)
using namespace std;
ll n,m,s,t,res,ans,A,B,T,X,Y;
ll Cal(ll a,ll b){return max(1ll*,n-a+)*max(1ll*,m-b+)%M;}
int main()
{
scanf("%lld%lld%lld",&n,&m,&s);
go(a,,M){if(a*a>s)break;
go(b,a?:,M){if((res=a*a+b*b)>s)break;
if(1ll*a*s%res||1ll*b*s%res)continue;
A=a*s/res,B=b*s/res;T=res==s?:;
if(a==||b==)T/=;X=b+A;Y=max(a,B);
(ans+=T*Cal(X,Y)+T*Cal(Y,X))%=M;
}}printf("%lld",(ans%M+M)%M);return ;
}//Paul_Guderian

如果青春是一捧鲜花,我愿把它洒给你,

如果生命是一场燃烧的旧梦,

我愿在梦醒前燃烬……   ————汪峰《忧郁的眼睛》

【无语凝噎(wordless)】的更多相关文章

  1. 【转】关于phpcms的学习

    在实现PHPCMS网站过程中,根据业务需求,我们遇到很多问题,特此总结如下,以便大家参考学习. [1]PHPCMS V9系统目录简析 在研究所有问题之前,请先了解一下系统的文件目录结构,具体如下图所示 ...

  2. PHPCMS V9 学习总结

    在实现PHPCMS网站过程中,根据业务需求,我们遇到很多问题,特此总结如下,以便大家参考学习. [1]PHPCMS V9系统目录简析 在研究所有问题之前,请先了解一下系统的文件目录结构,具体如下图所示 ...

  3. 微信JSSDK与录音相关的坑

    欢迎各位转载, 以让微信团队重视这些恼人的BUG. 请注明出处微信JSSDK与录音相关的坑 by lzl124631x 最近一直在做微信JSSDK与录音相关的功能开发, 遇到了各种奇尺大坑, 时不时冷 ...

  4. PHPCMS V9 学习总结(转)

    转自:http://www.cnblogs.com/Braveliu/p/5074930.html 在实现PHPCMS网站过程中,根据业务需求,我们遇到很多问题,特此总结如下,以便大家参考学习. [1 ...

  5. phpcms图文总结(转)

    转自:http://www.cnblogs.com/Braveliu/p/5074930.html 在实现PHPCMS网站过程中,根据业务需求,我们遇到很多问题,特此总结如下,以便大家参考学习. [1 ...

  6. 微信JSSDK与录音相关的坑

    微信JSSDK与录音相关的坑 最近一直在做微信JSSDK与录音相关的功能开发, 遇到了各种奇尺大坑, 时不时冷不丁地被坑一道, 让我时常想嘶吼: "微信JSSDK就是个大腊鸡!!!!!!!! ...

  7. 模仿某旅行网站 纯css实现背景放大效果

    基本功能是鼠标移动到图片上,对应宽度变宽.其中布局和基本样式直接copy官网,功能部分是自己瞎鼓捣实现的. 直接上代码: HTML部分 <div class="fold_wrap&qu ...

  8. Python-GUI编程-PyQt5

    Python-GUI编程-PyQt5 1. GUI编程是什么? GUI 全称为: Graphical User Interface;简称GUI翻译为中文为: 图形化用户接口简单理解就是:- 使用Pyt ...

  9. #学习笔记#e2e学习使用(一)

    本文仅限于记录本人学习的过程,以及怎么踩的坑,是如何解决的.逻辑肯定是混乱的,有用之处会抽出共通另行发帖. 最终目标:要运用于Vue项目中,进行功能测试甚至自动化测试. 一.e2e概念 理解:end ...

随机推荐

  1. 第十一条:谨慎的覆盖clone()方法

    一个类要想实现克隆,需要实现Cloneable接口,表明这个类的对象具有克隆的功能. Cloneable接口是一个mixin接口,它里面并没有任何的抽象方法,类似的接口有Serializable接口, ...

  2. 使用Github pages+jekyll搭建自己的博客(windows版)

    最近突发奇想,想试试GitHub pages来搭建博客.网上一搜一大堆,嗯...看来还是挺简单的...于是自己撸起袖子干...... 结果对于我这种GitHub注册过,git 没用过,ruby.jek ...

  3. node创建第一个应用

    如果我们使用PHP来编写后端的代码时,需要Apache 或者 Nginx 的HTTP 服务器,并配上 mod_php5 模块和php-cgi. 从这个角度看,整个"接收 HTTP 请求并提供 ...

  4. javascript单例模式及开发实践

    定义: 保证一个对象(类)仅有一个实例,并提供一个访问它的全局访问点: 实现原理: 利用闭包来保持对一个局部变量的引用,这个变量保存着首次创建的唯一的实例; 主要用于: 全局缓存.登录浮窗等只需要唯一 ...

  5. RSA的公钥、私钥

    一.举个例子 1.发消息 用对方的公钥给对方发消息 2.发公告 发公告的时候,用自己的私钥形成签名! 二.加密和签名 RSA的公钥.私钥是互相对应的,RSA会生成两个密钥,你可以把任何一个用于公钥,然 ...

  6. Vue全家桶

    简介 “简单却不失优雅,小巧而不乏大匠”. Vue.js 是一个JavaScriptMVVM库,是一套构建用户界面的渐进式框架.它是以数据驱动和组件化的思想构建的,采用自底向上增量开发的设计. 为什么 ...

  7. notepad++运行Python

    1.打开notepad++的菜单栏,点击run 2.输入cmd /k python "$(FULL_CURRENT_PATH)" & PAUSE & EXIT 3. ...

  8. Python入门之PyCharm的快捷键与常用设置和扩展(Win系统)

    1.  PyCharm的快捷键 2 . PyCharm的常用设置和扩展 ---------------------------------------------------------------- ...

  9. 上传视频使用ffmpeg自动截取缩略图

    上传视频之后,有的需要显示缩略图,而不是仅仅显示视频名称的列表,这时候就需要对上传的视频截取缩略图. 简单粗暴点,将以下代码作为工具类复制粘贴即可: package com.util; import ...

  10. python基础—迭代器、生成器

    python基础-迭代器.生成器 1 迭代器定义 迭代的意思是重复做一些事很多次,就像在循环中做的那样. 只要该对象可以实现__iter__方法,就可以进行迭代. 迭代对象调用__iter__方法会返 ...