题解 AtCoder Beginner Contest 168
小兔的话
欢迎大家在评论区留言哦~
A - ∴ (Therefore)
B - ... (Triple Dots)
C - : (Colon)
D - .. (Double Dots)
E - ∙ (Bullet)
简单题意
小兔捕获了 \(N\) 条不同的沙丁鱼,第 \(i\) 条沙丁鱼的 美味程度 和 香味程度 分别是 \(A_i\) 和 \(B_i\)
她想在这些沙丁鱼中选择 一条 或者 多条 放入冷冻箱;但是必须保证沙丁鱼的选择是合格的
(合格的定义:其中的任意两条沙丁鱼 \(i\) 和 \(j\) 都不满足 \(A_i \times A_j + B_i \times B_j = 0\))
小兔想知道有多少种选择沙丁鱼的方法(选择的沙丁鱼的集合相同,算同一种方法),答案对 \(1e9 +7\) 取模
数据范围
\(1 \leq N \leq 2 \times 10^5\)
\(-10^{18} \leq A_i, B_i \leq 10^{18}\)
知识点
- 数学知识
- 最大公约数 \(\mathrm{gcd}\)
- 快速幂
- STL
mappair
分析
需要不满足的式子与 \(i\) 和 \(j\) 的关系太大了,不妨化简一下:
\]
我们可以把 \(\frac{A_i}{B_i}\) 相同的分成一组,统计出属于这一组的沙丁鱼的数量,再把 \(\frac{A_i}{B_i}\) 和 \(- \frac{B_j}{A_j}\) 的两组分成一对,这一对肯定是互相满足的(就是 \(C\) 与 \(D\) 是一对,反过来 \(D\) 肯定与 \(C\) 是一对,\(D\) 不会和其它成为一对)
我们计算每一对里的选择方案,把所有的选择方案数乘起来再 减一(排除全部不选的情况),就是最终的答案了
如何计算每一对里的选择方案呢?
可以先计算每一对中每组的选择方案,设属于这一组的沙丁鱼有 \(s\) 条,选择沙丁鱼的方案数就是 \(2^s\)(每条鱼有 被选择 和 不被选择 \(2\) 种情况)
那么每一对的方案数就是 \(s_1 + s_2 - 1\)
- 因为其中的两组是不能同时选的,所以是 \(+\) 而不是 \(\times\)
- 因为在统计 \(s_1\) 被选的时候,\(s_2\) 一定是不选的;同理,在统计 \(s_2\) 被选的时候,\(s_1\) 一定是不选的;需要减去这 \(2\) 种多算的情况;又因为 \(2\) 组都不选也是 \(1\) 种合格的情况,所以又要加上 \(1\) 种情况,所以是 \(+1\)
代码
#include <cstdio>
#include <map>
#include <utility>
using namespace std;
#define int long long
int Gcd(int u, int v) { return (v == 0) ? u : Gcd(v, u % v); }
int Max(int u, int v) { return (u > v) ? u : v; }
int Min(int u, int v) { return (u < v) ? u : v; }
int rint()
{
int x = 0, fx = 1; char c = getchar();
while (c < '0' || c > '9') { fx ^= ((c == '-') ? 1 : 0); c = getchar(); }
while ('0' <= c && c <= '9') { x = (x << 3) + (x << 1) + (c ^ 48); c = getchar(); }
if (!fx) return -x;
return x;
}
int qpow(int u, int v, int Mod)
{
int ans = 1; u %= Mod;
while (v)
{
if (v & 1) ans = ans * u % Mod;
u = u * u % Mod; v >>= 1;
}
return ans;
}
const int MOD = 1e9 + 7;
const int MAX_n = 2e5;
int n, ans = 1, sum = 0;
int A[MAX_n + 5];
int B[MAX_n + 5];
map<pair<int, int>, int> G;
map<pair<int, int>, bool> vis;
signed main()
{
n = rint();
for (int i = 1; i <= n; i++)
{
A[i] = rint(), B[i] = rint();
if (A[i] == 0 && B[i] == 0)
{
++sum; --i; --n; continue;
}
int temp = Gcd(A[i], B[i]);
A[i] /= temp; B[i] /= temp;
if (A[i] < 0) { A[i] = -A[i]; B[i] = -B[i]; }
++G[make_pair(A[i], B[i])];
}
for (int i = 1; i <= n; i++)
{
pair<int, int> now = make_pair(A[i], B[i]);
if (-B[i] < 0) { B[i] = -B[i]; A[i] = -A[i]; }
pair<int, int> other = make_pair(-B[i], A[i]);
if (vis[now] || vis[other]) continue;
vis[now] = vis[other] = true;
ans = ans * ((qpow(2, G[now], MOD) + qpow(2, G[other], MOD) - 1) % MOD) % MOD;
}
printf("%lld\n", (ans - 1 + sum + MOD) % MOD);
return 0;
}
F - . (Single Dot)
题解 AtCoder Beginner Contest 168的更多相关文章
- AtCoder Beginner Contest 168
比赛链接:https://atcoder.jp/contests/abc168/tasks A - ∴ (Therefore) 题意 给出一个由数字组成的字符串 $s$,要求如下: 如果 $s$ 以 ...
- Atcoder Beginner Contest 168 D - .. (Double Dots) (BFS)
题意:有\(n\)个房间,在这些房间中两两连\(m\)次条边,问除了第一个房间,其他房间走到第一个房间的最短路径,输出这个房间所连的上一个房间,如果走不到,输出\(no\). 题解:刚开始我写了一个d ...
- [题解] Atcoder Beginner Contest ABC 270 G Ex 题解
点我看题 G - Sequence in mod P 稍微观察一下就会发现,进行x次操作后的结果是\(A^xS+(1+\cdots +A^{x-1})B\).如果没有右边那一坨关于B的东西,那我们要求 ...
- [题解] Atcoder Beginner Contest ABC 265 Ex No-capture Lance Game DP,二维FFT
题目 首先明确先手的棋子是往左走的,将其称为棋子1:后手的棋子是往右走的,将其称为棋子2. 如果有一些行满足1在2右边,也就是面对面,那其实就是一个nim,每一行都是一堆石子,数量是两个棋子之间的空格 ...
- AtCoder Beginner Contest 154 题解
人生第一场 AtCoder,纪念一下 话说年后的 AtCoder 比赛怎么这么少啊(大雾 AtCoder Beginner Contest 154 题解 A - Remaining Balls We ...
- AtCoder Beginner Contest 153 题解
目录 AtCoder Beginner Contest 153 题解 A - Serval vs Monster 题意 做法 程序 B - Common Raccoon vs Monster 题意 做 ...
- AtCoder Beginner Contest 177 题解
AtCoder Beginner Contest 177 题解 目录 AtCoder Beginner Contest 177 题解 A - Don't be late B - Substring C ...
- KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解
KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解 哦淦我已经菜到被ABC吊打了. A - Century 首先把当前年 ...
- AtCoder Beginner Contest 184 题解
AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...
随机推荐
- linux系统ifconfig中网卡名和网卡配置文件名称不同的解决办法
比如我的配置文件, cd /etc/sysconfig/network-scripts/ifcfg-eth1是这个名称,但是我使用ifconfig显示的信息却是 eth0,很明显这不是我配置文件的名称 ...
- MySQL 通过.frm文件和.ibd文件实现InnoDB引擎的数据恢复
起因是这样的,公司的领导表示说服务器崩了,修理好之后,只剩下数据库目录下的物理文件(即.frm文件与.ibd文件).然后,整了一份压缩包给我,叫我瞅一下能不能把数据恢复出来.我当场愣了一下,这都啥文件 ...
- 解决使用go get 下载模块下载超时的问题
解决使用go get 下载模块下载超时的问题 解决使用go get 下载模块下载超时的问题 使用go env可以看到,默认的GOPROXY的值是https://proxy.golang.org, ...
- 单线程service服务
1.@Service修饰类名,同时类继承Thread类 @Service public class MasterSchedulerService extends Thread { /** * logg ...
- ffmpeg architecture(中)
ffmpeg architecture(中) 艰苦学习FFmpeg libav 您是否不奇怪有时会发出声音和视觉? 由于FFmpeg作为命令行工具非常有用,可以对媒体文件执行基本任务,因此如何在程序中 ...
- 编译原理-文法(G)和语言(L)
1.设文法G2(S): S->AB A->aA|a B->bB|b G2(S)产生的语言是什么? 解:L(G2)={ambn|m,n≥1} 2.请给出产生语言为{anbn|n≥1}的 ...
- 工作流引擎Activiti使用进阶!详细解析工作流框架中高级功能的使用示例
Activiti高级功能简介 Activit的高级用例,会超越BPMN 2.0流程的范畴,使用Activiti高级功能需要有Activiti开发的明确目标和足够的Activiti开发经验 监听流程解析 ...
- QueryTable的使用以及错误
1.QuerySeter的filter使用遇到的错误 1.1 Filter里的字段名和操作符要用双下划线."__" 不是" _",否则会被认为成是列名的一部分, ...
- 04:全局解释器锁(GIL)
1 全局解释器锁(GIL) 0 pypy(没有全局解释器锁) cpython(99.999999%) -pypy python好多模块用不了,1 全局解释器锁,GIL锁(cpython解释器的问 ...
- Python使用websocket调用语音识别,语音转文字
@ 目录 0. 太长不看系列,直接使用 1. Python调用标贝科技语音识别websocket接口,实现语音转文字 1.1 环境准备: 1.2 获取权限 1.2.1 登录 1.2.2 创建新应用 1 ...