JZOJ 【NOIP2016提高A组集训第16场11.15】SJR的直线
JZOJ 【NOIP2016提高A组集训第16场11.15】SJR的直线
题目
Description

Input

Output

Sample Input
6
0 1 0
-5 3 0
-5 -2 25
0 1 -3
0 1 -2
-4 -5 29
Sample Output
10
Data Constraint

题解
题意
给出\(n\)个条直线的解析式,问这些直线能组成多少个三角形
题解
发现直接求解不容易求
想到可以先求出最大数量再减去不合法的
最大数量\(C_n^3\),不合法的有两种
- 两条平行线+一条不平行的
- 三条平行线
那么可以求出斜率然后按照斜率排序,求出每种相同斜率的个数\(c[i]\),和总共斜率的个数\(t\)
答案就是\(C_n^3-\sum_{i=1}^tC_{c[i]}^2*(n-c[i])+C_{c[i]}^3\)
Code
#include<cstdio>
#include<algorithm>
#define mod 1000000007
using namespace std;
long long n,ans,t,c[300001];
struct node
{
	long long x,y,z;
}s[300001];
long long read()
{
	long long res=0,fh=1;char ch=getchar();
	while ((ch<'0'||ch>'9')&&ch!='-') ch=getchar();
	if (ch=='-') fh=-1,ch=getchar();
	while (ch>='0'&&ch<='9') res=(res<<1)+(res<<3)+(ch-'0'),ch=getchar();
	return res*fh;
}
bool cmp(node x,node y)
{
	double pd1=x.y?(double)-x.x/x.y:1e100;
	double pd2=y.y?(double)-y.x/y.y:1e100;
	return pd1<pd2;
}
long long C3(long long x) {return (x*(x-1)*(x-2)/6%mod);}
long long C2(long long x) {return (x*(x-1)/2)%mod;}
int main()
{
	freopen("trokuti.in","r",stdin);
	freopen("trokuti.out","w",stdout);
	n=read();
	ans=C3(n);
	for (int i=1;i<=n;++i)
		s[i].x=read(),s[i].y=read(),s[i].z=read();
	sort(s+1,s+n+1,cmp);
	int i=1,j=1;
	while (i<=n)
	{
		while (j<=n&&s[i].x*s[j].y==s[i].y*s[j].x) ++j;
		c[++t]=j-i;
		i=j;
	}
	for (int i=1;i<=t;++i)
		ans=(ans+mod-(C2(c[i])*(n-c[i])%mod)-C3(c[i])+mod)%mod;
	printf("%lld\n",ans);
	fclose(stdin);
	fclose(stdout);
	return 0;
}
JZOJ 【NOIP2016提高A组集训第16场11.15】SJR的直线的更多相关文章
- JZOJ 【NOIP2016提高A组集训第16场11.15】兔子
		JZOJ [NOIP2016提高A组集训第16场11.15]兔子 题目 Description 在一片草原上有N个兔子窝,每个窝里住着一只兔子,有M条路径连接这些窝.更特殊地是,至多只有一个兔子窝有3 ... 
- 【JZOJ4895】【NOIP2016提高A组集训第16场11.15】三部曲
		=v= 因为外来的入侵,国王决定在某些城市加派士兵.所有城市初始士兵数量为0.当城市 被加派了k名士兵时.城市i的所有子城市需要被加派k+1名士兵.这些子城市的所有子城市需要被加派k+2名士兵.以此类 ... 
- 【JZOJ4894】【NOIP2016提高A组集训第16场11.15】SJR的直线
		题目描述 数据范围 解法 考虑逐次加入每一条直线. 对于当前已加入的直线集合L,现在要新加入一条直线l. 那么它产生的贡献,与平行线有关. 对于任意三条直线,如果其中任意两条平行,那么将不做贡献. 所 ... 
- 【JZOJ4896】【NOIP2016提高A组集训第16场11.15】兔子
		题目描述 在一片草原上有N个兔子窝,每个窝里住着一只兔子,有M条路径连接这些窝.更特殊地是,至多只有一个兔子窝有3条或更多的路径与它相连,其它的兔子窝只有1条或2条路径与其相连.换句话讲,这些兔子窝之 ... 
- 【JZOJ4898】【NOIP2016提高A组集训第17场11.16】人生的价值
		题目描述 NiroBC终于找到了人生的意义,可是她已经老了,在新世界,没有人认识她,她孤独地在病榻上回顾着自己平凡的一生,老泪纵横.NiroBC多么渴望再多活一会儿啊! 突然一个戴着黑色方框眼镜,方脸 ... 
- 【JZOJ4899】【NOIP2016提高A组集训第17场11.16】雪之国度
		题目描述 雪之国度有N座城市,依次编号为1到N,又有M条道路连接了其中的城市,每一条道路都连接了不同的2个城市,任何两座不同的城市之间可能不止一条道路.雪之女王赋予了每一座城市不同的能量,其中第i座城 ... 
- 【JZOJ4841】【NOIP2016提高A组集训第4场11.1】平衡的子集
		题目描述 夏令营有N个人,每个人的力气为M(i).请大家从这N个人中选出若干人,如果这些人可以分成两组且两组力气之和完全相等,则称为一个合法的选法,问有多少种合法的选法? 数据范围 40%的数据满足: ... 
- 【NOIP2016提高A组集训第4场11.1】平衡的子集
		题目 夏令营有N个人,每个人的力气为M(i).请大家从这N个人中选出若干人,如果这些人可以分成两组且两组力气之和完全相等,则称为一个合法的选法,问有多少种合法的选法? 分析 如果暴力枚举每个人被分到哪 ... 
- 【NOIP2016提高A组集训第14场11.12】随机游走——期望+树形DP
		好久没有写过题解了--现在感觉以前的题解弱爆了,还有这么多访问量-- 没有考虑别人的感受,没有放描述.代码,题解也写得歪歪扭扭. 并且我要强烈谴责某些写题解的代码不打注释的人,像天书那样,不是写给普通 ... 
随机推荐
- [论文阅读] RNN 在阿里DIEN中的应用
			[论文阅读] RNN 在阿里DIEN中的应用 0x00 摘要 本文基于阿里推荐DIEN代码,梳理了下RNN一些概念,以及TensorFlow中的部分源码.本博客旨在帮助小伙伴们详细了解每一步骤以及为什 ... 
- 像用excel一样用pandas
			1 说明 预计需要15min阅读此教材: 本教材仅讲述如何查看excel数据,筛选,排序,查找替换数据,不涉及excel中复杂的图形绘制及样式修改. 2 假设 假设,已经存在一个test.xlsx文件 ... 
- layui表单一
			1. ***首先明确一点 表单的以来加载模块是 form.如果不加载form模块,select.checkbox.radio等将无法显示,并且无法使用form相关功能. 我们用layui官网的样本来做 ... 
- 【java】校验当前时间是否在规定的时间内
			废话不多说直接贴代码. 我的日期格式是 8:00-22:00 要用的自己换下格式哈. public class CheckClosingTimeUtil { /** * 校验当前时间是否在规定时间内 ... 
- 快速识别烂项目!试试这款项目代码统计IDEA插件
			编程是一个很奇妙的事情,大部分的我们把大部分时间实际都花在了复制粘贴,而后修改代码上面. 很多时候,我们并不关注代码质量,只要功能能实现,我才不管一个类的代码有多长.一个方法的代码有多长. 因此,我们 ... 
- 内网渗透 day9-免杀基础
			免杀1 目录 1. 会话提升的几种方式 1 2. armitage的熟悉 2 3. handler生成监听器的方法 6 4. 防止会话假死 6 5. 控制台设置编码 7 6. upx加壳 7 7. m ... 
- springboot mybatis保存数据中文保存成???
			springboot mybatis保存数据中文保存成??? 解决方法: 数据库存连接配置后面加characterEncoding=UTF-8 如下例: spring.datasource.url=j ... 
- vue-count-to(简单好用的一个数字滚动插件)
			vue-count-to是一个无依赖,轻量级的vue组件,可覆盖easingFn. 1. 你可以设置两个属性startVal和endVal,它会自动判断计数或倒计时.支持vue-ssr.vue-cou ... 
- [leetcode/lintcode 题解] 微软 面试题:实现 Trie(前缀树)
			实现一个 Trie,包含 insert, search, 和 startsWith 这三个方法. 在线评测地址:领扣题库官网 样例 1: 输入: insert(" ... 
- Javaer 进阶必看的 RocketMQ ,就这篇了
			每个时代,都不会亏待会学习的人. 大家好,我是 yes. 继上一篇 头条终面:写个消息中间件 ,我提到实现消息中间件的一些关键点,今天就和大家一起深入生产级别消息中间件 - RocketMQ 的内核实 ... 
