题解

有什么LNOI啊,最后都是JLOI罢了

一道非常……懵逼的统计题

当然是容斥,所有的方案 - 至少有一个点坏掉的正方形 + 至少有两个点坏掉的正方形 - 至少有三个点坏掉的正方形 + 至少有四个点坏掉的正方形

总共的方案就是

\(\sum_{i}^{min(n,m)}i \* (n - i + 1) \* (m - i + 1)\)

至少有一个点坏掉的怎么统计,我们考虑这个点在底边,左边有l个坐标右边有r个坐标,上面有h个坐标

设\(z = min(l + r,h)\)

如果高度大于左右两边,那么总共的是\(\frac{z(z + 1)}{2} + z\)

如果有超出的部分,即\(z > l\),或\(z > r\)设差值为n,则多出去的就是\(\frac{n(n + 1)}{2}\)

然后两两枚举点对,最后统计出来的3个点要除3,统计出来4个点的要除6

代码

#include <cstdio>
#include <algorithm>
#include <cstring>
#include <iostream>
#include <map>
#define MAXN 100005
#define pii pair<int,int>
#define fi first
#define se second
//#define ivorysi
using namespace std;
typedef long long int64;
int N,M,K;
pii P[2005];
map<pii,bool> mmm;
const int MOD = 100000007;
int64 ans,cnt2,cnt3,cnt4;
void sub(int l,int r,int h) {
int z = min(l + r,h);
ans -= 1LL * z * (z + 3) / 2;
if(z > l) ans += 1LL * (z - l) * (z - l + 1) / 2;
if(z > r) ans += 1LL * (z - r) * (z - r + 1) / 2;
ans = (ans % MOD + MOD) % MOD;
}
bool in_range(int x,int l,int r) {
if(x >= l && x <= r) return 1;
return 0;
}
void check(pii A,pii B) {
if(!in_range(A.fi,0,N) || !in_range(A.se,0,M) || !in_range(B.fi,0,N) || !in_range(B.se,0,M)) return;
++cnt2;
int t = mmm.count(A) + mmm.count(B);
if(t >= 1) ++cnt3;
if(t >= 2) ++cnt4,++cnt3;
}
void Solve() {
scanf("%d%d%d",&N,&M,&K);
for(int i = 1 ; i <= K ; ++i) {
scanf("%d%d",&P[i].fi,&P[i].se);
mmm[P[i]] = 1;
} for(int i = 1 ; i <= min(N,M) ; ++i) {
ans += 1LL * i * (N - i + 1) % MOD * (M - i + 1) % MOD;
ans %= MOD;
}
for(int i = 1 ; i <= K ; ++i) {
sub(P[i].fi,N - P[i].fi,P[i].se);
sub(P[i].fi,N - P[i].fi,M - P[i].se);
sub(P[i].se,M - P[i].se,P[i].fi);
sub(P[i].se,M - P[i].se,N - P[i].fi);
ans += min(P[i].fi,P[i].se);
ans += min(P[i].fi,M - P[i].se);
ans += min(N - P[i].fi,P[i].se);
ans += min(N - P[i].fi,M - P[i].se);
ans %= MOD;
}
for(int i = 1 ; i <= K ; ++i) {
for(int j = i + 1 ; j <= K ; ++j) {
int dx = P[i].fi - P[j].fi,dy = P[i].se - P[j].se;
check(make_pair(P[i].fi - dy,P[i].se + dx),make_pair(P[j].fi - dy,P[j].se + dx));
check(make_pair(P[i].fi + dy,P[i].se - dx),make_pair(P[j].fi + dy,P[j].se - dx));
if(abs(dx) + abs(dy) & 1) continue;
int x = (dx - dy) >> 1,y = (dx + dy) >> 1;
check(make_pair(P[i].fi - x,P[i].se - y),make_pair(P[j].fi + x,P[j].se + y));
}
}
ans += cnt2 - cnt3 / 3 + cnt4 / 6;
ans = (ans % MOD + MOD) % MOD;
printf("%lld\n",ans);
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
}

【LOJ】 #2025. 「JLOI / SHOI2016」方的更多相关文章

  1. loj #2025. 「JLOI / SHOI2016」方

    #2025. 「JLOI / SHOI2016」方   题目描述 上帝说,不要圆,要方,于是便有了这道题. 由于我们应该方,而且最好能够尽量方,所以上帝派我们来找正方形.上帝把我们派到了一个有 NNN ...

  2. loj #2024. 「JLOI / SHOI2016」侦查守卫

    #2024. 「JLOI / SHOI2016」侦查守卫   题目描述 小 R 和 B 神正在玩一款游戏.这款游戏的地图由 nnn 个点和 n−1n - 1n−1 条无向边组成,每条无向边连接两个点, ...

  3. loj #2026. 「JLOI / SHOI2016」成绩比较

    #2026. 「JLOI / SHOI2016」成绩比较   题目描述 THU 的 G 系中有许许多多的大牛,比如小 R 的室友 B 神.B 神已经厌倦了与其他的同学比较 GPA(Grade Poin ...

  4. LOJ #2026「JLOI / SHOI2016」成绩比较

    很好的锻炼推柿子能力的题目 LOJ #2026 题意 有$n$个人$ m$门学科,第$ i$门的分数为不大于$U_i$的一个正整数 定义A「打爆」B当且仅当A的每门学科的分数都不低于B的该门学科的分数 ...

  5. 【LOJ】#2026. 「JLOI / SHOI2016」成绩比较

    题解 用\(f[i][j]\)表示考虑了前i个排名有j个人被碾压 \(f[i][j] = f[i - 1][k] \* C[k][j] \* C[N - k - 1][N - r[i] - j] \* ...

  6. 【LOJ】#2024. 「JLOI / SHOI2016」侦查守卫

    题解 童年的回忆! 想当初,这是我考的第一次省选,我当时初二,我什么都不会,然后看着这个东西,是不是能用我一个月前才会的求lca,光这个lca我就调了一个多小时= =,然后整场五个小时,我觉得其他题不 ...

  7. loj2026 「JLOI / SHOI2016」成绩比较

    orz #include <iostream> #include <cstdio> using namespace std; typedef long long ll; int ...

  8. loj2024「JLOI / SHOI2016」侦查守卫

    too hard #include <iostream> #include <cstdio> using namespace std; int n, d, m, uu, vv, ...

  9. Loj #2495. 「AHOI / HNOI2018」转盘

    Loj #2495. 「AHOI / HNOI2018」转盘 题目描述 一次小 G 和小 H 原本准备去聚餐,但由于太麻烦了于是题面简化如下: 一个转盘上有摆成一圈的 \(n\) 个物品(编号 \(1 ...

随机推荐

  1. vue+element 切换正式和测试环境

    1.package.json { "name": "element-starter", "description": "A Vue ...

  2. vscode nodejs智能提示功能

    1.依赖一些第三方的插件,先安装typings这个包,如果使用的是淘宝镜像,输入cnpm.cmd执行: cnpm i typings -g //cnpm install typings -global ...

  3. 经典幻灯片插件Swiper

    照着写的demo,搞清楚什么叫分页器Pagination,什么叫nav,搞清楚DOM结构,container,wrapper之类的,就能写了.效果掉渣天! <!DOCTYPE html> ...

  4. 样式缩写——css技巧(一)

    一.margin和padding缩写 例: .sample-margin1{ margin-top:15px; margin-right:20px; margin-bottom:12px; margi ...

  5. jQuery中下拉框select的操作方法详解

    最近在写页面的时候常常遇到要动态增删改下拉框select的情况,由于我比较习惯用jquery框架来架构我的前端js,所以就顺便把各种jquery操作下拉框select的方法总结了一下,收藏起来以便下次 ...

  6. 20155321 2016-2017-2 《Java程序设计》第六周学习总结

    20155321 2016-2017-2 <Java程序设计>第六周学习总结 教材学习内容总结 第十章 IO 流 IO 流用来处理设备之间的数据传输 Java对数据的操作是通过流的方式 J ...

  7. 基本控件文档-UIKit结构图

    CHENYILONG Blog 基本控件文档-UIKit结构图 Fullscreen   UIKit结构图 技术博客http://www.cnblogs.com/ChenYilong/ 新浪微博htt ...

  8. 在springMVC中使用自定义注解来进行登录拦截控制

    1:java注解使用是相当频繁,特别是在搭建一些框架时,用到类的反射获取方法和属性,用的尤其多. java中元注解有四个: @Retention     @Target     @Document  ...

  9. 【leetcode 简单】 第八十九题 赎金信

    给定一个赎金信 (ransom) 字符串和一个杂志(magazine)字符串,判断第一个字符串ransom能不能由第二个字符串magazines里面的字符构成.如果可以构成,返回 true :否则返回 ...

  10. Oracle GoldenGate常用参数

    OGG(Oracle GoldenGate)参数介绍 所有的GoldenGate进程均有参数文件 Manager Extract Replicat Utilities 所有参数均有缺省配置 实际应用只 ...