数三角count(归类)
评测方式:文本比较
题目描述
这是一个数三角的游戏。长度为1或SQRT(2)的小木棍放在一个网格上。如图所示,有水平的,垂直的或对角的。对角放置的木棍可以交叉。
avatar
将木棍随意地放在网格上得到的图案可能不含三角形,也可能含一个或多个三角形。如下图所示,
avatar
(a),(b),,(d)和(e)分别含有2,5,12,0,0个三角形。你的任务是写一个程序数出一个图案中的三角形个数。。cpp
输入格式
输入文件count.in包括N+1行:
先输入图案中木棍的个数N。下面输入这N根木棍的位置,用两个网格坐标表示,这两个坐标分别为木棍两端的位置。网格大小不超过10´10,因此网格左下和右上的坐标分别为(0,0)和(9,9)。
输出格式
输入文件count.out包括1行:
三角形的个数。
样例
样例输入
3
0 0 0 1
0 0 1 0
0 1 1 0
样例输出
1
题目分析
这道题有许多细节的地方,而主要方法是描述线段,然后枚举各个点,判断是否是三角形,因为有交叉的情况,我们可以把一个格子分成四个
易错点
1可能会有两条线交叉的情况
2.有三点共线的情况
具体思路(描述线段)
1.当这条线段是竖着的
if(y1>y2)
{
pd[x1][y2][x1][y2+1]=1;
pd[x1][y2+1][x1][y2]=1;
pd[x1][y2+1][x1][y1]=1;
pd[x1][y1][x1][y2+1]=1;
}
else
{
pd[x1][y1][x1][y1+1]=1;
pd[x1][y1+1][x1][y1]=1;
pd[x1][y1+1][x1][y2]=1;
pd[x1][y2][x1][y1+1]=1;
}
2当这条线段是横着的
if(x1<x2)
{
pd[x1][y1][x1+1][y1]=1;
pd[x1+1][y1][x1][y1]=1;
pd[x1+1][y1][x2][y1]=1;
pd[x2][y1][x1+1][y1]=1;
}
else
{
pd[x2][y1][x2+1][y1]=1;
pd[x2+1][y1][x2][y1]=1;
pd[x2+1][y1][x1][y1]=1;
pd[x1][y1][x2+1][y1]=1;
}
3.当这条线段是斜着的
if(x1+y1-x2-y2==4)
{
pd[x2+1][y2+1][x1][y1]=1;
pd[x1][y1][x2+1][y2+1]=1;
pd[x2+1][y2+1][x2][y2]=1;
pd[x2][y2][x2+1][y2+1]=1;
}
if(x2+y2-x1-y1==4)
{
pd[x1+1][y1+1][x2][y2]=1;
pd[x2][y2][x1+1][y1+1]=1;
pd[x1+1][y1+1][x1][y1]=1;
pd[x1][y1][x1+1][y1+1]=1;
}
if(x1+y1==x2+y2)
{
pd[x1][y1][(x1+x2)/2][(y1+y2)/2]=1;
pd[(x1+x2)/2][(y1+y2)/2][x1][y1]=1;
pd[x2][y2][(x1+x2)/2][(y1+y2)/2]=1;
pd[(x1+x2)/2][(y1+y2)/2][x2][y2]=1;
}
}
4.然后就是可以对三角形进行统计不果,因为重复所以要/6;
#include<cstdio>
int pd[55][55][55][55];
int n;
int ans;
int x1,x2,y1,y2;
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
x1*=2;
y1*=2;
x2*=2;
y2*=2;
if(x1==x2)
{
if(y1>y2)
{
pd[x1][y2][x1][y2+1]=1;
pd[x1][y2+1][x1][y2]=1;
pd[x1][y2+1][x1][y1]=1;
pd[x1][y1][x1][y2+1]=1;
}
else
{
pd[x1][y1][x1][y1+1]=1;
pd[x1][y1+1][x1][y1]=1;
pd[x1][y1+1][x1][y2]=1;
pd[x1][y2][x1][y1+1]=1;
}
}
if(y1==y2)
{
if(x1<x2)
{
pd[x1][y1][x1+1][y1]=1;
pd[x1+1][y1][x1][y1]=1;
pd[x1+1][y1][x2][y1]=1;
pd[x2][y1][x1+1][y1]=1;
}
else
{
pd[x2][y1][x2+1][y1]=1;
pd[x2+1][y1][x2][y1]=1;
pd[x2+1][y1][x1][y1]=1;
pd[x1][y1][x2+1][y1]=1;
}
}
if(x1+y1-x2-y2==4)
{
pd[x2+1][y2+1][x1][y1]=1;
pd[x1][y1][x2+1][y2+1]=1;
pd[x2+1][y2+1][x2][y2]=1;
pd[x2][y2][x2+1][y2+1]=1;
}
if(x2+y2-x1-y1==4)
{
pd[x1+1][y1+1][x2][y2]=1;
pd[x2][y2][x1+1][y1+1]=1;
pd[x1+1][y1+1][x1][y1]=1;
pd[x1][y1][x1+1][y1+1]=1;
}
if(x1+y1==x2+y2)
{
pd[x1][y1][(x1+x2)/2][(y1+y2)/2]=1;
pd[(x1+x2)/2][(y1+y2)/2][x1][y1]=1;
pd[x2][y2][(x1+x2)/2][(y1+y2)/2]=1;
pd[(x1+x2)/2][(y1+y2)/2][x2][y2]=1;
}
pd[x1][y1][x2][y2]=1;
pd[x2][y2][x1][y1]=1;
}
for (int i = 0; i <= 18; i++) {
for (int j = 0; j <= 18; j++) {
for (int z = 0; z <= 18; z++) {
for (int i1 = 0; i1 <= 18; i1++) {
for (int j1 = 0; j1 <= 18; j1++) {
for (int z1 = 0; z1 <= 18; z1++) {
if (pd[i][i1][j][j1] == 1 && pd[i][i1][z][z1] == 1 && !(i == j && i1 == j1) && !(i == z && i1 == z1) && (z1 - i1) * (j - i) - (j1 - i1) * (z - i) == 0 && pd[j][j1][z][z1] == 0 &&
pd[z][z1][j][j1] == 0) {
pd[j][j1][z][z1] = 1;
pd[z][z1][j][j1] = 1;
}
}
}
}
}
}
}
for(int i=0;i<=18;i++)
{
for(int j=0;j<=18;j++)
{
for(int k=0;k<=18;k++)
{
for(int i1=0;i1<=18;i1++)
{
for(int j1=0;j1<=18;j1++)
{
for(int k1=0;k1<=18;k1++)
{
if(pd[i][i1][j][j1]&&pd[j][j1][k][k1]&&pd[i][i1][k][k1]&&!(i1==j1&&i==j)&&!(i==k&&i1==k1)&&!(k==j&&k1==j1)&&((k1 - i1) * (j - i) - (j1 - i1) * (k - i) != 0))
{
ans++;
}
}
}
}
}
}
}
printf("%d",ans/6);
}
数三角count(归类)的更多相关文章
- hibernate 数据行数统计 count(*)
Hibernate关于sql中的count(*)数据统计: ①如果使用的是HQL: 直接在HQL中使用count(*)即可获取行数 Long count = (Long)HibernateUtil.g ...
- (转载)MySQL 统计数据行数 Select Count
(转载)http://www.5idev.com/p-php_mysql_select_count.shtml 统计数据行数 SELECT COUNT() FROM 语法用于从数据表中统计数据行数. ...
- MySQL 统计行数的 count
MySQL count() 函数我们并不陌生,用来统计每张表的函数.但如果你的表越来越大,并且是 InnoDB 引擎的话,会发现计算的速度会越来越慢.在这篇文章里,会先介绍 count() 实现的原理 ...
- sql-函数avg,count,max,min,sum
常用函数 AVG (平均) COUNT (计数) MAX (最大值) MIN (最小值) SUM (总合) 运用函数的语法是: SELECT "函数名"("栏位名&qu ...
- MySql中对Group by后的结果数进行Count
今天在写MySQ的SQL语句的时候遇到了一个奇怪的问题 select count(*) from subsitealbum t1, photo t2,files t3 where t1.SourceA ...
- oracle count 百万级 分页查询记要总数、总条数优化
oracle count 百万级 分页查询记录总数.总条数优化 oracle count 百万级 查询记录总数.总条数优化 最近做一个项目时,做分页时,发现分页查询速度很慢,分页我做的是两次查询,一次 ...
- 剑指Offer面试题:29.丑数
一.题目:丑数 题目:我们把只包含因子2.3和5的数称作丑数(Ugly Number).求按从小到大的顺序的第1500个丑数.例如6.8都是丑数,但14不是,因为它包含因子7.习惯上我们把1当做第一个 ...
- group by 查询分组后 组的条数
比如select gid from table group by gid 查询时使用下面的方法查询条数 select count(distinct gid) from table 使用select c ...
- entity framework 新手入门篇(3)-entity framework实现orderby,count,groupby,like,in,分页等
前面我们已经学习了entityframework的基本的增删改查,今天,我们将在EF中实现一些更加贴近于实际功能的SQL方法. 承接上面的部分,我们有一个叫做House的数据库,其中包含house表和 ...
随机推荐
- Element-ui 中对表单进行验证
Element-ui 中对表单(Form)绑定的对象中的对象属性进行校验 如果是直接绑定属性,是可以的,但是绑定对象中的属性就需要特别处理,需要在rules中添加双引号 " "或者 ...
- Mockito 简介
Mockito 是一种 Java Mock 框架,主要是用来做 Mock 测试,它可以模拟任何 Spring 管理的 Bean.模拟方法的返回值.模拟抛出异常等等,在了解 Mockito 的具体用法之 ...
- 阿里云esc 安装 mysql5.7.27
1. 下载: wget http://repo.mysql.com/mysql57-community-release-el7-10.noarch.rpm 2. 安装: (1) yum -y in ...
- 机器学习算法中的评价指标(准确率、召回率、F值、ROC、AUC等)
参考链接:https://www.cnblogs.com/Zhi-Z/p/8728168.html 具体更详细的可以查阅周志华的西瓜书第二章,写的非常详细~ 一.机器学习性能评估指标 1.准确率(Ac ...
- .net core Winform 添加DI和读取配置、添加log
首先新建配置类 public class CaptureOption { /// <summary> /// 是否自启 /// </summary> public bool A ...
- Python基础入门(5)- 函数的定义与使用
定义函数 函数的定义 函数的分类 函数的创建方法 函数的返回return 函数的定义 将一件事情的步骤封装在一起并得到最终结果 函数名代表了这个函数要做的事情 函数体是实现函数功能的流程 函数可以帮助 ...
- java 注解的几大作用及使用方法详解
初学者可以这样理解注解:想像代码具有生命,注解就是对于代码中某些鲜活个体的贴上去的一张标签.简化来讲,注解如同一张标签. 在未开始学习任何注解具体语法而言,你可以把注解看成一张标签.这有助于你快速地理 ...
- 服务器安装Centos7
目录 一.安装 一.安装 1.开启虚拟机后会出现以下界面 Install CentOS 7 安装CentOS 7 Test this media & install CentOS 7 测试安装 ...
- Windows11下载地址
10月5日微软推出了Win11正式版本,但是仍然不支持apk格式,不免让人失望.下面是Win11商业版本下载地址: 下载地址1: ed2k://|file|zh-cn_windows_11_busin ...
- LuoguB2013 温度表达转化 题解
Content 输入华氏温度 \(F\),请将其转化为摄氏温度 \(C\),精确到小数点后 \(5\) 位. 数据范围:\(F\geqslant -459.67\). Solution 简单的输入输出 ...