nssl1143,jzoj3493-三角形【排序,数学,几何】

正题

纪中题目链接:https://jzoj.net/senior/#main/show/3493


题目大意

给n点,求有多少个三角形。


##解题思路
我们考虑在n个点中选取3个点的方案数,Cn3C_n^3Cn3。然后不能组成三角形的情况只有3点共线。利用容斥原理我们可以用方案数减去不合法的方案数。现在问题变为了n个点中有多个个3点共线。
我们枚举一个点,然后求出他和其他点的斜率,将斜率排序再计算有多少个方案选取两个斜率相同的点就是答案。
(注意判断tan90°的情况)
误差听说要在10−910^{-9}109以内

时间复杂度:O(n2logn)O(n^2log\ n)O(n2log n)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 3010
#define inf 2147483647
#define eps 1e-9
using namespace std;
int n,x[N],y[N];
double p[N];
long long ans;
int main()
{//freopen("triangle.in","r",stdin);//freopen("triangle.out","w",stdout);scanf("%d",&n);for(int i=1;i<=n;i++)scanf("%d%d",&x[i],&y[i]);ans+=(long long)(n-2)*(n-1)*n/6;//总方案数for(int i=3;i<=n;i++){int num=0;for(int j=1;j<i;j++){double a1=x[i]-x[j],b1=y[i]-y[j];if(!b1) num++;//tan90°p[j]=a1/b1;//计算斜率}sort(p+1,p+i);p[i]=2147483647;int k=1;for(int j=1;j<i;j++)if(p[j+1]-p[j]<eps) k++;//斜率相等else{ans-=k*(k-1)/2;//去除不合法方案k=1;}ans-=num*(num-1)/2;//tan90°}printf("%lld",ans);
}

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

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

相关文章

网页弹框弹出

完成这个功能需要在 弹框弹出 点击之后 才会显示内容 <!DOCTYPE html> <html><head><title>对话框测试</title><script>alert("对话框测试");</script></head><body>对话框测试&#xff1a;</body> …

字符串工具类总结(全)

文章目录前言代码展示大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 现在是&#xff1a;2022年7月9日18:53:37 前言 最近在项目过程中整理了一些常用的方法&#xff0c;于是将其抽出来形成一个工具类。 下面我来分享一下我自己整理的一…

Azure School与开源

距离Azure School(https://school.azure.cn/) 的正式上线时间&#xff0c;2017.8.3&#xff0c;已经过去了20多天了。这20多天得到了很多有帮助的建议和反馈&#xff0c;小伙伴们都很给力&#xff0c;互相帮助扶持&#xff0c;调整产品不正确的地方&#xff0c;快速迭代新的功能…

ssl提高组周六模拟赛【2018.9.8】

前言 开学后&#xff0c;新学年新气象&#xff0c;学校题库也迎来了新的改动&#xff0c;界面大改变&#xff0c;也可以比赛了。 所以这周就有比赛了&#xff0c;而在纪中被虐习惯后回来渴望继续被虐就来参加提高组模拟赛&#xff08;反正今年也参加提高组&#xff09; 成绩 …

select count(*)底层究竟干了啥么?

转载自 select count(*)底层究竟干了啥么&#xff1f; “SELECT COUNT( * ) FROM t” 是个再常见不过的 SQL 需求了。在 MySQL 的使用规范中&#xff0c;我们一般使用事务引擎 InnoDB 作为(一般业务)表的存储引擎&#xff0c;在此前提下&#xff0c;COUNT( * )操作的时间复杂…

linux系统中启动tomcat报错Cannot find /root/tomcat/bin/setclasspath.sh

今天在启动tomcat的时候莫名其妙的报了个这个错&#xff0c;在网上搜好多都说是要改配置文件啥的&#xff0c;都挺麻烦的。 我觉得我的问题不是配置文件的问题&#xff0c;就没有去改&#xff0c;找到了个新方法。 只需要在终端输入命令&#xff1a; unset CATALINA_HOME然后…

c关于数组的疑惑

#include<stdio.h>main(){char a[]"asdas";printf("%s\n",a);}不明白为什么【】【不需要加数字】 #include<stdio.h>main(){int a[]{1};printf("%d\n",a);}在这里插入代码片结果为很大的数

为什么不应该重写service方法

转载自 为什么不应该重写service方法 故事通常是这样开始的&#xff1a; 从前&#xff0c;有一个程序猿&#xff0c;他语重心长地对孙子说&#xff1a;“孩子&#xff0c;要是你以后写servlet&#xff0c;最好不要重写service方法啊” 孙子大为不解&#xff0c;程序猿又说&…

.net core之ACG小站爬虫(二)

紧跟着上一节说的文章&#xff0c;虽然已经放出了所写的全代码&#xff0c;但还是再解释一下另外一个页面的请求和分析过程吧。PS&#xff1a;又可以愉快的水一章了&#xff0c;咕嘿嘿。页面分析上回说到下载按钮的href属性是javascript:;伪协议&#xff0c;导致了新打开的页面…

P1541-乌龟棋【多维dp】

正题 评测记录链接:https://www.luogu.org/recordnew/lists?uid52918&pidP1541 题目大意 在不同的格子停留会获得不同的价值&#xff0c;有m张移动牌&#xff0c;可以移动1∼41∼4步&#xff08;每张牌固定&#xff09;&#xff0c;求最大价值。 解题思路 用fx1,x2,x3,…

判断一个数是否为素数

#include<stdio.h> main(){ int m,n;printf("请输入一个数我来给你判断是否是素数&#xff1a;\n");scanf("%d",&m);if((m%40&&m%100!0)||m%4000){printf("该数是素数");} else{printf("该数不是素数");} }

Correct the classpath of your application so that it contains compatible versions of the classes com

大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号雄雄的小课堂 在使用springboot集成camunda卡蒙达工作流引擎时报错&#xff0c;报错信息如下&#xff1a; Description: An attempt was made to call a method that does not exist. The attempt was made from th…

.net core之ACG小站爬虫(一)

想到好久没写过.net的代码了&#xff0c;因此就尝试来写一写.net的代码。此外&#xff0c;也想要熟悉一下Phantomjs。环境配置.net core下载。可选的可以下载宇宙大IDEVisual Studio&#xff0c;当然更加推荐使用Visual Studio Code进行代码的书写。Phantomjs。这个不用说了&am…

数组:完成等差等比数列,及其他数列

有没有想过用c语言来编写一些数列呢&#xff0c;编写数列&#xff0c;数组是最好的选择。 等差&#xff1a; #include<stdio.h> main(){ int a[1000],b,i;a[0]1;scanf("%d",&b);for(i0;i<b;i){a[i1]a[i]2;}for(i0;i<b;i){printf("a%d%-8d\t&q…

Spring MVC竟然有5种参数绑定的方式?你知道几种?

转载自 Spring MVC竟然有5种参数绑定的方式&#xff1f;你知道几种&#xff1f; SpringMVC参数绑定&#xff0c;简单来说就是将客户端请求的key/value数据绑定到controller方法的形参上&#xff0c;然后就可以在controller中使用该参数了下面通过5个常用的注解演示下如何进行参…

微服务中如何切换配置文件、部署

大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 最近改了个微服务的项目&#xff0c;在本身的业务上加上一个演示的业务。 以前没有弄过微服务的项目&#xff0c;这次改完之后&#xff0c;部署花了不少时间&#xff0c;一方面是因为服务器…

P1063-能量项链【区间dp】

正题 评测记录:https://www.luogu.org/recordnew/lists?uid52918&pidP1063 题目大意 有n个珠子组成环&#xff0c;每颗珠子的头尾标记连接&#xff0c;将两颗珠子合并会产生headi∗headj∗tailjheadi∗headj∗tailj的能量&#xff0c;产生一颗头标记为头珠子的头标记&am…

asp.net core mvc View Component 应用

ViewComponent1、View 组件介绍在ASP.NET CORE MVC中,View组件有点类似于partial views,但是他们更强大&#xff0c;View组件不能使用model binding,当你调用它的时候仅仅依赖与你提供的数据一个View组件特点&#xff1a;.呈现一大块而不是一个整体的响应。 .包含在控制器和视…

分离三位数

#include<stdio.h> main(){ int k,l,m,n;printf("请输入一个三位数"); scanf("%d",&k);lk/100;mk/10%10;nk%10;printf("这个三位数的百位是:%d\n",l);printf("这个三位数的十位是:%d\n",m);printf("这个三位数的个位是…

@Autowired注入RedisCache报错空指针

大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 今天在改一个几年前写的项目中的代码&#xff0c;其中有个地方用到了缓存&#xff0c;不过代码中用的是&#xff1a;CacheUtils,也不是报错&#xff0c;但是就是在并发的时候有问题&#xf…