题目描述

六十年一次的魔法战争就要开始了,大魔法师准备从附近的魔法场中汲取魔法能量。

大魔法师有mm个魔法物品,编号分别为1,2,...,m1,2,...,m。每个物品具有一个魔法值,我们用X_iXi​表示编号为i的物品的魔法值。每个魔法值Xi是不超过n的正整数,可能有多个物品的魔法值相同。

大魔法师认为,当且仅当四个编号为a,b,c,da,b,c,d的魔法物品满足x_a<x_b<x_c<x_d,X_b-X_a=2(X_d-X_c)xa​<xb​<xc​<xd​,Xb​−Xa​=2(Xd​−Xc​),并且x_b-x_a<(x_c-x_b)/3xb​−xa​<(xc​−xb​)/3时,这四个魔法物品形成了一个魔法阵,他称这四个魔法物品分别为这个魔法阵的AA物品,BB物品,CC物品,DD物品。

现在,大魔法师想要知道,对于每个魔法物品,作为某个魔法阵的AA物品出现的次数,作为BB物品的次数,作为CC物品的次数,和作为DD物品的次数。

输入输出格式

输入格式:

第一行包含两个空格隔开的正整数n,mn,m。

接下来mm行,每行一个正整数,第i+1i+1行的正整数表示X_iXi​,即编号为ii的物品的魔法值。

保证1 \le n \le 150001≤n≤15000,1 \le m \le 400001≤m≤40000,1 \le Xi \le n1≤Xi≤n。每个X_iXi​是分别在合法范围内等概率随机生成的。

输出格式:

共mm行,每行44个整数。第ii行的44个整数依次表示编号为ii的物品作 为A,B,C,DA,B,C,D物品分别出现的次数。

保证标准输出中的每个数都不会超过10^9109。每行相邻的两个数之间用恰好一个空格隔开。

输入输出样例

输入样例#1: 复制

30 8
1
24
7
28
5
29
26
24
输出样例#1: 复制

4 0 0 0
0 0 1 0
0 2 0 0
0 0 1 1
1 3 0 0
0 0 0 2
0 0 2 2
0 0 1 0
输入样例#2: 复制

15 15
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
输出样例#2: 复制

5 0 0 0
4 0 0 0
3 5 0 0
2 4 0 0
1 3 0 0
0 2 0 0
0 1 0 0
0 0 0 0
0 0 0 0
0 0 1 0
0 0 2 1
0 0 3 2
0 0 4 3
0 0 5 4
0 0 0 5

说明

【样例解释1】

共有55个魔法阵,分别为:

物品1,3,7,61,3,7,6,其魔法值分别为1,7,26,291,7,26,29;

物品1,5,2,71,5,2,7,其魔法值分别为1,5,24,261,5,24,26;

物品1,5,7,41,5,7,4,其魔法值分别为1,5,26,281,5,26,28;

物品1,5,8,71,5,8,7,其魔法值分别为1,5,24,261,5,24,26;

物品5,3,4,65,3,4,6,其魔法值分别为5,7,28,295,7,28,29。

以物品55为例,它作为AA物品出现了11次,作为BB物品出现了33次,没有作为CC物品或者DD物品出现,所以这一行输出的四个数依次为1,3,0,01,3,0,0。

此外,如果我们将输出看作一个mm行44列的矩阵,那么每一列上的mm个数之和都应等于魔法阵的总数。所以,如果你的输出不满足这个性质,那么这个输出一定不正确。你可以通过这个性质在一定程度上检查你的输出的正确性。

【数据规模】

首先吐槽一下,本来是考试前准备放松心情的,可最后的那个优化还是没有想到,心态爆炸,难受

第一个思路肯定就是m^4的纯模拟算法,可以拿到60分。

之后看到想法1根本没有用到题目中给定的n,n比m小,而且如果两个物品的魔法值相等,那么他们可以作为的魔法阵的情况也一定是一样的,可以考虑搞一个桶,题给条件中是有一个等式的,所以只需要枚举a,b,c,优化到n^3

仍然是TLE的,大概可以通过的算法是n^2,还需要再去掉一重,只能是前缀和优化了(反正我是没有想到23333)

分析一下全部的条件

a<b<c<d

b-a=2*(d-c)

3*(b-a)<c-b

整理一下,令d-c=t,则可以得到

b-a=2*t

b-c>6*t

如果枚举t的值,再枚举d的值,还需要枚举出全部的a,b,但是这时就可以考虑前缀和优化了,因为只要对于较小的c,d满足的a,b一定对于较大的c,d满足,所以可以再去掉一重循环。

 #include<algorithm>
#include<iostream>
#include<cstdio>
using namespace std;
int n,m,res[][],a[],t[];
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
{
scanf("%d",&a[i]);
t[a[i]]++;
}
for(int i=;*i<=n;i++)
{
int sum=,va,vb,vc,vd;
for(vd=*i+;vd<=n;vd++)
{
va=vd-*i-;
vb=va+*i;
vc=vd-i;
sum+=t[va]*t[vb];
res[][vc]+=sum*t[vd];
res[][vd]+=sum*t[vc];
}
sum=;
for(va=n-*i-;va>=;va--)
{
vb=va+*i;
vc=vb+*i+;
vd=vc+i;
sum+=t[vc]*t[vd];
res[][va]+=sum*t[vb];
res[][vb]+=sum*t[va];
}
}
for(int i=;i<=m;i++)
printf("%d %d %d %d\n",res[][a[i]],res[][a[i]],res[][a[i]],res[][a[i]]);
return ;
}

洛谷 P2119 魔法阵的更多相关文章

  1. 洛谷P2119 魔法阵

    P2119 魔法阵 题目描述 六十年一次的魔法战争就要开始了,大魔法师准备从附近的魔法场中汲取魔法能量. 大魔法师有m个魔法物品,编号分别为1,2,...,m.每个物品具有一个魔法值,我们用Xi表示编 ...

  2. 洛谷P1585 魔法阵

    题目传送门 这题就是一个有技巧的DFS+一大堆乱七八糟的剪枝 进行DFS时注意一下以下点 根据题意,我们可以把DFS分成两块,即1--n*m/2与n*m/2--n*m,第一块边找边记录,第二块就开始计 ...

  3. [洛谷P2730] 魔板 Magic Squares

    洛谷题目链接:魔板 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 我们知道魔板的每一个方格都 ...

  4. P2119 魔法阵

    原题链接  https://www.luogu.org/problemnew/show/P2119 YY同学今天上午给我们讲了这个题目,我觉得她的思路很好,特此写这篇博客整理一下. 50分:暴力枚举 ...

  5. 洛谷P2730 魔板 [广搜,字符串,STL]

    题目传送门 魔板 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 我们知道魔板的每一个方格都有 ...

  6. 洛谷 P2730 魔板 Magic Squares 解题报告

    P2730 魔板 Magic Squares 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 ...

  7. 洛谷P1275 魔板

    P1275 魔板 题目描述 有这样一种魔板:它是一个长方形的面板,被划分成n行m列的n*m个方格.每个方格内有一个小灯泡,灯泡的状态有两种(亮或暗).我们可以通过若干操作使魔板从一个状态改变为另一个状 ...

  8. 洛谷 P2730 魔板 Magic Squares

    P2730 魔板 Magic Squares 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 ...

  9. 洛谷 P1275 魔板

    P1275 魔板 题目描述 有这样一种魔板:它是一个长方形的面板,被划分成n行m列的n*m个方格.每个方格内有一个小灯泡,灯泡的状态有两种(亮或暗).我们可以通过若干操作使魔板从一个状态改变为另一个状 ...

随机推荐

  1. Pessimistic and Optimistic locking

    事务隔离通常通过锁定任何对事务中资源的访问来实现的.总的来说,有两种方法针对事务的锁定:乐观锁(Pessimistic locking)和悲观锁(Optimistic locking) 悲观锁(Pes ...

  2. SpringBoot开发案例之整合Dubbo分布式服务

    前言 在 SpringBoot 很火热的时候,阿里巴巴的分布式框架 Dubbo 不知是处于什么考虑,在停更N年之后终于进行维护了.在之前的微服务中,使用的是当当维护的版本 Dubbox,整合方式也是使 ...

  3. 记录一次.Net框架Bug发现和提交过程:.Net Framework和.Net Core均受影响

    SmtpClient一处代码编写错误导致异步发送邮件时DeliveryFormat配置项无法正确工作,异步操作已经完全不受我们设置属性控制了,UTF-8内容(如中文)转不转码完全看对方邮件服务器心情! ...

  4. Sql 调优总结

    1前言 Sql 语句调优对应用性能非常重要,看了几篇文章,总结了一下数据库优化的方法. 2 数据库 Sql 优化 1 对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by ...

  5. Mysql多实例之mysql服务脚本

    1. #init port=3306 mysql_user="root" mysql_pwd="cancer" CmdPath="/applicati ...

  6. 论一类每次修改log个结点更新的线段树标记方法

    楼房重建(BZOJ2957) 多次询问一个区间中大于区间内这个数之前所有数的数的数量. 每个线段树结点维护该节点的答案c和区间内最大值m.假设有函数get(x,cm)=结点x中答案>cm的长度. ...

  7. A. Chess Placing

    链接 [https://codeforces.com/contest/985/problem/A] 题意 给你一个偶数n,输入n/2个数,代表棋子的位置,有一个1*n的棋盘是黑白相间的 问你使得所有棋 ...

  8. (Beta)团队贡献分

    Beta阶段团队每个成员都积极响应一起完成了开发, 所以最后我们一致决定各个成员的贡献分相同. 林珣玙 53 康家华 52 张启东 51 刘彦熙 49 马瑶华 48 仇栋民 47

  9. Python_列表初识及操作

    列表 列表初识 列表属于容器性数据类型. li = [123, '狗', True, [1, 2, 3], {'name': 'Lon'}, (1, 2, 3)] 其中包含有int型,例如123:字符 ...

  10. Python之拆分目录

    成分目录的好习惯,使得代码保持整洁,为以后的代码管理提供方便. 一.概念 一般目录有以下几个: bin:程序入口,存放start文件. conf:存放固定的配置信息,比如:连接redis的配置信息.连 ...