Codeforces 975D. Ghosts
Description
给出一条直线 \(a*x+b\) 上的 \(n\) 个点,每一个点有一个速度 \((v_x,v_y)\),求 \(T=[-oo,oo]\) 相交的次数乘以 \(2\)
题面
Solution
横纵坐标分开考虑
横坐标相等的时刻 \(T_x=\frac{x_j-x_i}{v_{x_i}-v_{x_j}}\)
总坐标相等的时刻 \(T_y=\frac{a(x_j-x_i)}{v_{y_i}-v_{y_j}}\)
\(T_x=T_y\)
\(v_{y_i}-a*v_{x_i}=v_{y_j}-a*v_{x_j}\)
用 \(map\) 记录一下出现次数就行了,注意要减去平行的情况
#include<bits/stdc++.h>
using namespace std;
template<class T>void gi(T &x){
	int f;char c;
	for(f=1,c=getchar();c<'0'||c>'9';c=getchar())if(c=='-')f=-1;
	for(x=0;c<='9'&&c>='0';c=getchar())x=x*10+(c&15);x*=f;
}
const int N=2e5+10;
typedef long long ll;
int n,a,b;
map<ll,int>S;
map<pair<int,int>,int>T;
int main(){
  freopen("pp.in","r",stdin);
  freopen("pp.out","w",stdout);
  ll ans=0;
  int x,vx,vy;
  cin>>n>>a>>b;
  for(int i=1;i<=n;i++){
	  gi(x);gi(vx);gi(vy);
	  ll t=vy-1ll*a*vx;
	  ans+=(S[t]-T[make_pair(vx,vy)])<<1;
	  S[t]++;T[make_pair(vx,vy)]++;
  }
  cout<<ans<<endl;
  return 0;
}
												
											Codeforces 975D. Ghosts的更多相关文章
- Codeforces 975D
		
题意略. 思路:我们来写一下公式: P1:(x1 + t * Vx1,y1 + t * Vy1) P2:(x2 + t * Vx2,y2 + t * Vy2) x1 + ...
 - 贪心+模拟 Codeforces Round #288 (Div. 2) C. Anya and Ghosts
		
题目传送门 /* 贪心 + 模拟:首先,如果蜡烛的燃烧时间小于最少需要点燃的蜡烛数一定是-1(蜡烛是1秒点一支), num[g[i]]记录每个鬼访问时已点燃的蜡烛数,若不够,tmp为还需要的蜡烛数, ...
 - CodeForces 508C Anya and Ghosts
		
Anya and Ghosts Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u S ...
 - Codeforces Round #288 (Div. 2) C. Anya and Ghosts 模拟
		
C. Anya and Ghosts time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
 - Codeforces Round #288 (Div. 2) C. Anya and Ghosts 模拟 贪心
		
C. Anya and Ghosts time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
 - 【codeforces 508C】Anya and Ghosts
		
[题目链接]:http://codeforces.com/contest/508/problem/C [题意] 每秒钟可以点一根蜡烛; 这根蜡烛会燃烧t秒; 然后会有m只鬼来拜访你; 要求在鬼来拜访你 ...
 - Codeforces Round #478 Div2 975A 975B 975C 975D
		
A. Aramic script 题目大意: 对于每个单词,定义一种集合,这个集合包含且仅包含单词中出现的字母.给你一堆单词,问有多少种这种集合. 题解: 状压,插入set,取size #in ...
 - CodeForces 508C  Anya and Ghosts 贪心
		
做不出题目,只能怪自己不认真 题目: Click here 题意: 给你3个数m,t,r分别表示鬼的数量,每只蜡烛持续燃烧的时间,每个鬼来时要至少亮着的蜡烛数量,接下来m个数分别表示每个鬼来的时间点( ...
 - 【map离散&容斥】Ghosts @Codeforces Round #478 (Div. 2) D
		
传送门 题意:给你一条直线的斜率a和截距b,和某一时刻n个在直线上的点的横坐标,以及沿坐标轴方向的速度.问你这些点在(-∞,+∞)的时间内的碰撞次数. solution 设两个点在t时刻相碰,有: x ...
 
随机推荐
- linux------深入理解linux内核
			
linux内核用到了很多数据结构,这些数据结构都是为了提高某些方面的效率. 内核分配给进程的虚拟地址空间由以下内存区组成: 程序的可执行代码 程序的初始化数据 程序的未初始化数据 初始程序栈(即用户态 ...
 - 在构造函数和析构函数中调用虚函数------新标准c++程序设计
			
在构造函数和析构函数中调用虚函数不是多态,因为编译时即可确定调用的是哪个函数.如果本类有该函数,调用的就是本类的函数:如果本类没有,调用的就是直接基类的函数:如果基类没有,调用的就是间接基类的函数,以 ...
 - C语言编程基础
			
主流C语言编译器介绍 关于GNU规范的语法扩展 用C语言构建一个可执行程序的流程 宏定义(无参宏定义和带参宏定义),C语言宏定义详解 条件编译,C语言条件编译详解 原码.反码.补码及位操作符,C语言位 ...
 - Tensorflow报错:InvalidArgumentError: You must feed a value for placeholder tensor 'input_y' with dtype
			
此错误神奇之处是每次第一次运行不会报错,第二次.第三次第四次....就都报错了.关掉重启,又不报错了,运行完再运行一次立马报错!搞笑! 折磨了我半天,终于被我给解决了! 问题解决来源于这边博客:htt ...
 - BZOJ4650/UOJ219 [Noi2016]优秀的拆分
			
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
 - dsp之BF531笔记
			
获得更多资料欢迎进入我的网站或者 csdn或者博客园 很久以前的BF531的笔记,觉得有用分享出来.摘自于open dsp 通用Gpio ADSP-BF53x 处理器上有16 个PF 接口,这些接口就 ...
 - P3994 高速公路  树形DP+斜率优化+二分
			
$ \color{#0066ff}{ 题目描述 }$ C国拥有一张四通八达的高速公路网树,其中有n个城市,城市之间由一共n-1条高速公路连接.除了首都1号城市,每个城市都有一家本地的客运公司,可以发车 ...
 - 条目四《用empty来代替检查size()是否为0》
			
条目四<用empty来代替检查size()是否为0> 首先先说结论: empty()实现为内联函数.(众所周知, 优秀的内联函数的效率比一般函数是高的) 在stl标准库中,empty()对 ...
 - 在DZ 中 showmessage 中可以再次执行 JS
			
showmessage ( '登录', '', array (), array ( 'showdialog' => 0, ...
 - POJ1358 Agri-Net
			
题目链接 就是裸的最小生成树,复习一下. prim算法: G=(V,E),V是点集,E是边集 假设T=(U,TE)是最小生成树.U,TE初始化为空 首先从V中任取一点 假设取V1,然后U={V1},只 ...