P2119 [NOIP2016 普及组] 魔法阵

P2119 [NOIP2016 普及组] 魔法阵

传送门

1

我们可以先写出\(O(m^4)\)的暴力

#include <bits/stdc++.h>  
#define int long long  
#define PII pair<int, int>  
using namespace std;  
const int inf = 0x3f3f3f3f;  
const int MOD = 1e9 + 7, N = 4e4 + 5;  
int n, m, ans[N][4];  struct Node  
{  int x, id;  friend bool operator< (Node x, Node y)  { return x.x < y.x; }  
}x[N];  signed main()  
{  scanf("%lld%lld", &m, &n);  for (int i = 1; i <= n; ++i)  scanf("%lld", &x[i].x), x[i].id = i;  sort(x + 1, x + 1 + n);  for (int a = 1; a <= n; ++a)  {  for (int b = a + 1; b <= n; ++b)  {  if (x[a].x == x[b].x) continue;  for (int c = n; c > b; --c)  {  if (4 * x[b].x >= 3 * x[a].x + x[c].x) break;  if (x[b].x == x[c].x) continue;  for (int d = c + 1; d <= n; ++d)  {  if (x[c].x == x[d].x) continue;  if (x[b].x - x[a].x != 2 * (x[d].x - x[c].x)) continue;  ++ans[x[a].id][0], ++ans[x[b].id][1], ++ans[x[c].id][2], ++ans[x[d].id][3];  }  }  }  }  for (int i = 1; i <= n; ++i)  printf("%lld %lld %lld %lld\n", ans[i][0], ans[i][1], ans[i][2], ans[i][3]);  return 0;  
}

其实这份代码是优化过一点的
比如

for (int c = n; c > b; --c)  if (4 * x[b].x >= 3 * x[a].x + x[c].x) break;  

\(c\)反着循环,\(c\)会越来越小,如果这条式子现在满足不了,以后也满足不了
分数\(65pts\)

2

接着我们可以看到\(n\)的数据范围比\(m\)
就会想到计数数组
可写出\(O(n^4)\)的暴力

#include <bits/stdc++.h>
#define int long long
#define PII pair<int, int>
using namespace std;
const int inf = 0x3f3f3f3f;
const int MOD = 1e9 + 7, N = 4e4 + 5;
int n, m, ans[N][4], mp[N], x[N];signed main()
{// freopen("magic.in", "r", stdin);// freopen("magic.out", "w", stdout);scanf("%lld%lld", &m, &n);for (int i = 1; i <= n; ++i)scanf("%lld", &x[i]), ++mp[x[i]];for (int a = 1; a <= m; ++a){if (!mp[a]) continue;for (int b = a + 1; b <= m; ++b){if (!mp[b]) continue;for (int c = m; c > b; --c){if (!mp[c]) continue;if (4 * b >= 3 * a + c) break;for (int d = c + 1; d <= m; ++d){if (!mp[d]) continue;if (b - a != 2 * (d - c)) continue;int tmp = mp[a] * mp[b] * mp[c] * mp[d];ans[a][0] += tmp / mp[a], ans[b][1] += tmp / mp[b];ans[c][2] += tmp / mp[c], ans[d][3] += tmp / mp[d];}}}}for (int i = 1; i <= n; ++i)printf("%lld %lld %lld %lld\n", ans[x[i]][0], ans[x[i]][1], ans[x[i]][2], ans[x[i]][3]);return 0;
}

分数: \(75pts\)

3

因为题目中说了 \(X_b-X_a=2(X_d-X_c)\)
所以,我们可以只枚举\(X_a, X_b, X_c\)

#include <bits/stdc++.h>
#define int long long
#define PII pair<int, int>
using namespace std;
const int inf = 0x3f3f3f3f;
const int MOD = 1e9 + 7, N = 4e4 + 5;
int n, m, ans[N][4], mp[N], x[N];signed main()
{// freopen("magic.in", "r", stdin);// freopen("magic.out", "w", stdout);scanf("%lld%lld", &m, &n);for (int i = 1; i <= n; ++i)scanf("%lld", &x[i]), ++mp[x[i]];for (int a = 1; a <= m; ++a){if (!mp[a]) continue;for (int b = a + 1; b <= m; ++b){if (!mp[b]) continue;if ((b - a) % 2) continue; // 因为式子是(b - a + 2 * c) / 2,c * 2一定是偶数,那么 b - a 也得是偶数for (int c = m; c > b; --c){if (!mp[c]) continue;if (4 * b >= 3 * a + c) break;int d = (b - a + 2 * c) / 2;if (!mp[d]) continue;int tmp = mp[a] * mp[b] * mp[c] * mp[d];ans[a][0] += tmp / mp[a], ans[b][1] += tmp / mp[b];ans[c][2] += tmp / mp[c], ans[d][3] += tmp / mp[d];}}}for (int i = 1; i <= n; ++i)printf("%lld %lld %lld %lld\n", ans[x[i]][0], ans[x[i]][1], ans[x[i]][2], ans[x[i]][3]);return 0;
}

分数: \(85pts\)

4

我们可以知道
输入图片说明
这样, 中间的\(>6x\)的数量可以用后缀和处理

\[\displaystyle C[i]+=\sum_{j=1}^{j+8x<i}mp[j]\times mp[j+2t]\times mp[i+t] \\ C[i] += mp[i+t]*\sum^{j+8t<i}_{j=1}cnt[j]\times cnt[j+2t] \\ \]

#include <bits/stdc++.h>  
#define int long long  
#define PII pair<int, int>  
using namespace std;  
const int inf = 0x3f3f3f3f;  
const int MOD = 1e9 + 7, N = 4e4 + 5;  
int n, m, ans[N][4], mp[N], val[N];  signed main()  
{  // freopen("magic.in", "r", stdin);  // freopen("magic.out", "w", stdout);  scanf("%lld%lld", &m, &n);  for (int i = 1; i <= n; ++i)  scanf("%lld", &val[i]), ++mp[val[i]];  for (int x = 1; 9 * x + 1 <= n; ++x)  {  int sum = 0;  int x7 = x * 7, x8 = x * 8, x9 = x * 9, x2 = x * 2;  for (int i = x9 + 2; i <= n; ++i)  {  sum += mp[i - x7 - 1] * mp[i - x9 - 1];  ans[i - x][2] += mp[i] * sum;  ans[i][3] += mp[i - x] * sum;  }  sum = 0;  for (int i = n - x9 - 1; i >= 1; --i)  {  sum += mp[i + x8 + 1] * mp[i + x9 + 1];  ans[i][0] += mp[i + x2] * sum;  ans[i + x2][1] += mp[i] * sum;  }  }  for (int i = 1; i <= n; ++i)  printf("%lld %lld %lld %lld\n", ans[val[i]][0], ans[val[i]][1], ans[val[i]][2], ans[val[i]][3]);  return 0;  
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/775832.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Tokitsukaze and Two Colorful Tapes

看这篇题解就好了 解释一下为什么山谷=山峰 证明加强结论:对于每个环,山谷=山峰 证:对于任何一种方案,这种方案下的任意一个环,我们断开某条边,他就会长成这个样子:起点和终点连起来,不难发现是山谷=山峰 再假设我们已经定下了山谷和山峰的个数\(a\),那么\(2(x-y)\)的…

从C++看C#托管内存与非托管内存

进程的内存 一个exe文件,在没有运行时,其磁盘存储空间格式为函数代码段+全局变量段。加载为内存后,其进程内存模式增加为函数代码段+全局变量段+函数调用栈+堆区。我们重点讨论堆区。进程内存函数代码段全局变量段函数调用栈堆区托管堆与非托管堆C# int a=10这种代码申请的内…

Magic-PDF:端到端PDF文档解析神器 构建高质量RAG必备!

项目结构流程解析 预处理的作用是判断文档内容是否需要进行OCR识别,如果是普通可编辑的PDF文档,则使用PyMuPDF库提取元信息。 模型层除了常规的OCR、版面结构分析外,还有公式检测模型,可提取公式内容,用于后续把公式转化为Latex格式。但是目前暂无表格内容识别,官方预计1…

Windows系统常用端口详解

135端口135主要用于Microsoft的远程过程调用(RPC)服务。RPCSS(Remote Procedure Call Subsystem) 服务是 COM 和 DCOM 服务器的服务控制管理器。它执行 COM 和 DCOM 服务器的对象激活请求、对象导出程序解析和分布式垃圾回收。如果此服务被停用或禁用,则使用 COM 或 DCOM 的…

Albumentations库使用

介绍Albumentations的核心使用方法,提供对应测试代码1 Albumentations库介绍 一个好用的开源图像处理库,适用于对RGB、灰度图、多光谱图像,以及对应的mask、边界框和关键点同时变换。通常用于数据增广,是PyTorch生态系统的一部分。 主页:https://albumentations.ai/ 2 核心…

LinkAI RAG知识库平台优化之路

LinkAI RAG知识库平台支持无结构文档、Q&A问答对、多列表格以及网站内容自动导入,并加入了自研的增强解析功能支持对文档中图片以及表格的自动解析。支持基于语义的向量检索和基于关键词的全文检索的增强混合检索功能,生成的回复可以标注答案来源,同时可以在使用记录中查…

14. 迭代器、生成器、模块与包、json模块

1.迭代器 1.1 迭代器介绍 迭代器是用来迭代取值的工具 每一次迭代得到的结果会作为下一次迭代的初始值,单纯的重复并不是迭代# while循环实现迭代取值 a = [1, 2, 3, 4, 5, 6] index = 0 while index < len(a):print(a[index])index += 1 1.2 可迭代对象 内置有_ _iter_ _方…

# 代码随想录二刷(哈希表)

代码随想录二刷(哈希表) 三数之和思路反正对于我来说是真的难想出来。若这道题还是采用哈希表的思路去做,非常麻烦,并且还要考虑去重的操作。所以这道题其实用双指针,是更方便的。具体程序如下: class Solution:def threeSum(self, nums: List[int]) -> List[List[int]]…

ctfshow-web入门-nodejs系列

web334 下载源码后缀改为zip打开即可 先对源码经行一个简单的分析 login.js// 引入Express框架 var express = require(express);// 创建一个路由实例 var router = express.Router();// 引入用户数据,假设user模块导出的是一个包含用户项的对象 var users = require(../modul…

2021年我因为Tab Session Manager丢失数据,好像是研究过一次leveldb的查看/解码方式 但是当时好像因为时间关系没能成功 / chrome .ldb文件

Default\Local Storage\leveldb .ldb2023年下半年我因为chatmindai修改域名,又研究过一次,因为时间关系也没有细究最近,我想查看一下anki的devtool的Local Storage,即https://ankiweb.net/shared/info/31746032这个插件产生的 C:\Users\xxx\AppData\Local\Anki\QtWebEngine…

联合省选 2024 Day2T1 迷宫守卫 题解

联合省选 2024 Day2T1 迷宫守卫 题解 好像距离联合省选已经半年了,前两天看到这题才想起来改,距离分班已经半年了,也算是好好学了半年了,但是还是那么菜,有点绷不住,感觉不如文化课 后来翻到题解区第二篇题解才知道自己赛时想的反悔贪心其实是正解,但是当时啥也不会,主…