[USACO18DEC] Cowpatibility G

news/2025/1/5 0:34:02/文章来源:https://www.cnblogs.com/YzaCsp/p/18648699

前言

想想自己做, 一共就两种 \(\rm{trick}\) 还不会?

思路

你发现两个不能和谐共处的奶牛, 当且仅当他们的 \(10\) 个喜好不重
因为要求时间复杂度不能是 \(\mathcal{O} (n^2)\) , 所以肯定要想办法做到不枚举点对

这个时候联想到之前的一道题 [CEOI2010 day2] pin, 我们考虑利用相似的方法 (结果之前那题是水过去的, 又去研究了一遍花费 \(10 \ \rm{min}\))

我们考虑「钦定」当前这只奶牛的 \(k\) 个喜好与其他奶牛相同, 这个时候我们可以轻松的 \(\mathcal{O}(1)\) 统计出有多少只, 仅仅需要使用 \(\rm{hash}\)
其中统计的总时间复杂度是 \(\mathcal{O} (2^{\omega} n)\) , 其中 \(\omega = 5\)

这不无敌了, 你发现令 \(f(k)\) 为「至多」\(k\) 个喜好与其他奶牛不同的对数, 可以快速计算出来 (即「钦定」\(\omega - k\) 个位置相同), 套路的, 令 \(g(k)\) 为「恰好」\(k\) 个喜好与其他奶牛不同的对数

\[f(k) = \sum_{i = 0}^{k} {\omega - i \choose \omega - k} g(i) \iff g(k) = \sum_{i = 0}^{k} (-1)^{k - i} {\omega - i \choose \omega - k} f(i) \]

容易发现

\[ans \gets g(\omega) = \sum_{i = 0}^{\omega} (-1)^{i + 1} f(i) \]

实现

\(\rm{TJ}\) 区并没有这种做法, 只能自己多考虑一下打出来了

框架

首先是计算 \(f\)
我们需要在枚举的过程中, 用二进制枚举的方式处理相同的喜好集合, 然后统计进 \(\rm{hash}\)

6, 注意到不能用 \(\rm{vector}\) , 而应该使用 \(\rm{set}\)

代码

#include <bits/stdc++.h>
#define int long long
const int MAXN = 5e4 + 20;int n;
int cows[MAXN][5];std::map<std::set<int>, int> hash; // 映射 hashint f[6];
/*计算 f(i)*/
void fcalc() {for (int i = 1; i <= n; i++) for (int s = 0; s < 32; s++) { // 枚举位置 / 状态std::set<int> ret; ret.clear(); for (int j = 0; j < 5; j++) if ((s >> j) & 1) ret.insert(cows[i][j]);f[5 - __builtin_popcount(s)] += hash[ret]; hash[ret]++;}
}signed main()
{scanf("%lld", &n);for (int i = 1; i <= n; i++) for (int j = 0; j < 5; j++) scanf("%lld", &cows[i][j]);fcalc();int ans = 0;for (int i = 0; i <= 5; i++) {ans += (i % 2 ? 1ll : -1ll) * f[i];}printf("%lld", ans);return 0;
}

总结

很像啊, 基本上逻辑相通

也算是常见 \(\rm{trick}\) , 本质上是观察到用 \(\rm{hash}\) 计算对数可以做到更快, 而且只有 \(\omega = 5\) 方便处理子集

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

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

相关文章

【政策解读】《电力监控系统安全防护规定》今日施行!

《电力监控系统安全防护规定》旨在提升电力监控系统的安全性和可靠性,确保电力系统的安全稳定运行。今日起施行,主要内容: 1、总则:《电力监控系统安全防护规定》旨在强化电力监控系统安全防护,保障电力系统安全稳定运行。规定适用于中国境内的电力监控系统运营者及相关单…

同硕计算机专业考研必备:统考+课程学习资料大放送!

同硕计算机,统考,课程学习,源码资料考研之路,道阻且长。对于计算机专业的学子来说,备考之路更是充满挑战。为了帮助广大考生高效备战,我在此精心整理了一套同硕计算机专业统考及课程学习资料,并免费分享给大家! 一、资料亮点:1. 同硕-计算机专业-统考历年真题,全部免…

【有源码】医院挂号系统+SpringBoot+VUE+前后端分离

学弟,学妹好,我是爱学习的学姐,今天带来一款优秀的项目:医院挂号系统。 本文介绍了系统功能与部署安装步骤,如果您有任何问题,也请联系学姐,偶现在是经验丰富的程序员! 一. 系统演示 管理后台-截图 前端-截图视频演示 https://githubs.xyz/show/329.mp4二. 系统概述 【…

基于图像形态学处理和凸包分析法的指尖检测matlab仿真

1.算法运行效果图预览 (完整程序运行后无水印)测试样本1: 测试样本2: 测试样本3: 2.算法运行软件版本 matlab2022a3.部分核心程序 (完整版代码包含详细中文注释和操作步骤视频)%提取手部轮廓坐标 handxy=func_find_hand_pxy(Im0_bw,Im0,Im0edge);figure; imshow(Im0); t…

云锵投资 2024 年收益统计及 12 月简报

年度统计量化基金小幅度跑输业绩基准; 量化股票由于平均1.8倍杠杆,加上有一定超额,所以最终跑出了 24.54%; 今年我个人在2月底部时加仓比较多,所以持股数增加了近一半; 由于有股指期货的持仓,权益类资产的整体杠杆较高,所以权益类资产今年获取60.12%的收益。 季报摘要行…

显卡危机的解决方案,全面解析ToDesk云电脑:服务配置与应用场景探索

ToDesk云电脑是一款集成了高性能计算资源的云端服务,旨在为用户提供便捷、高效、安全的计算体验。无论是游戏玩家、设计师还是企业用户,都能通过ToDesk云电脑享受到强大的计算能力和灵活的资源配置。ToDesk云电脑以其强大的性能、灵活的服务和优质的用户体验,正在迅速赢得市…

【有源码】周边旅游平台系统+SpringBoot+VUE+前后端分离

学弟,学妹好,我是爱学习的学姐,今天带来一款优秀的项目:流浪宠物管理系统。 本文介绍了系统功能与部署安装步骤,如果您有任何问题,也请联系学姐,偶现在是经验丰富的程序员! 一. 系统演示 管理后台-截图前端-截图 视频演示 https://githubs.xyz/show/327.mp4二. 系统概述…

01java反序列化基础

java反射的相关操作 一些重要的方法获取类的⽅法: forName实例化类对象的⽅法: newInstance获取函数的⽅法: getMethod执⾏函数的⽅法: invoke// eg.反射获取任意类的任意方法并执行 import java.lang.reflect.Method;public class ReflectionExample {public static void …

单元化架构最佳实践指南!

0 前言单元化架构通过减少故障影响范围来增强系统的弹性。 单元化架构是对于那些无法接受停机或可能对最终用户产生负面影响的系统的良好选择。 单元化架构可能很复杂,有一些最佳实践可以遵循,以提高成功的机会。 在推出单元化架构或将现有的云原生/微服务架构改造/转变为单元…

苹果鼠标有望加入 AI 语音控制功能;Accent Oracl :准确识别你口音的 AI 丨 RTE 开发者日报

开发者朋友们大家好:这里是 「RTE 开发者日报」 ,每天和大家一起看新闻、聊八卦。我们的社区编辑团队会整理分享 RTE(Real-Time Engagement) 领域内「有话题的 新闻 」、「有态度的 观点 」、「有意思的 数据 」、「有思考的 文章 」、「有看点的 会议 」,但内容仅代表编辑…

计算机网络复习应用层(第六章)

应用层 应用层的共同特点:C/S或者P2P、推/拉、面向文本/面向二进制域名系统(DNS) 名字到IP地址的解析互联网的域名空间 互联网采用了层次树状结构的命名方式采用:.四级域名.三级域名.二级域名.顶级域名 其中本地域名服务器向根域名服务器发出DNS请求,根域名服务器进行查找…

【有源码】流浪宠物管理系统+SpringBoot+VUE+前后端分离

学弟,学妹好,我是爱学习的学姐,今天带来一款优秀的项目:流浪宠物管理系统。 本文介绍了系统功能与部署安装步骤,如果您有任何问题,也请联系学姐,偶现在是经验丰富的程序员! 一. 系统演示 管理后台-截图前端-截图视频演示 https://githubs.xyz/show/326.mp4二. 系统概述…