评测方式:文本比较

题目描述

这是一个数三角的游戏。长度为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(归类)的更多相关文章

  1. hibernate 数据行数统计 count(*)

    Hibernate关于sql中的count(*)数据统计: ①如果使用的是HQL: 直接在HQL中使用count(*)即可获取行数 Long count = (Long)HibernateUtil.g ...

  2. (转载)MySQL 统计数据行数 Select Count

    (转载)http://www.5idev.com/p-php_mysql_select_count.shtml 统计数据行数 SELECT COUNT() FROM 语法用于从数据表中统计数据行数. ...

  3. MySQL 统计行数的 count

    MySQL count() 函数我们并不陌生,用来统计每张表的函数.但如果你的表越来越大,并且是 InnoDB 引擎的话,会发现计算的速度会越来越慢.在这篇文章里,会先介绍 count() 实现的原理 ...

  4. sql-函数avg,count,max,min,sum

     常用函数 AVG (平均) COUNT (计数) MAX (最大值) MIN (最小值) SUM (总合) 运用函数的语法是: SELECT "函数名"("栏位名&qu ...

  5. MySql中对Group by后的结果数进行Count

    今天在写MySQ的SQL语句的时候遇到了一个奇怪的问题 select count(*) from subsitealbum t1, photo t2,files t3 where t1.SourceA ...

  6. oracle count 百万级 分页查询记要总数、总条数优化

    oracle count 百万级 分页查询记录总数.总条数优化 oracle count 百万级 查询记录总数.总条数优化 最近做一个项目时,做分页时,发现分页查询速度很慢,分页我做的是两次查询,一次 ...

  7. 剑指Offer面试题:29.丑数

    一.题目:丑数 题目:我们把只包含因子2.3和5的数称作丑数(Ugly Number).求按从小到大的顺序的第1500个丑数.例如6.8都是丑数,但14不是,因为它包含因子7.习惯上我们把1当做第一个 ...

  8. group by 查询分组后 组的条数

    比如select gid from table group by gid 查询时使用下面的方法查询条数 select count(distinct gid) from table 使用select c ...

  9. entity framework 新手入门篇(3)-entity framework实现orderby,count,groupby,like,in,分页等

    前面我们已经学习了entityframework的基本的增删改查,今天,我们将在EF中实现一些更加贴近于实际功能的SQL方法. 承接上面的部分,我们有一个叫做House的数据库,其中包含house表和 ...

随机推荐

  1. clickhouse客户端使用

    测试初始化 clickhouse-client -m create database if not exists test; use test; drop table test; create tab ...

  2. virtualbox Linux安装增强功能

    1.点击<设备>--><安装增强功能> 2.创建安装包挂载目录,并挂载 #创建挂载目录 mkdir /mnt/cdrom #挂载光盘内容 mount -t auto -r ...

  3. Type of 'this' pointer in C++

    In C++, this pointer is passed as a hidden argument to all non-static member function calls. The typ ...

  4. Linux下安装gbd

    目录 一.简介 二.部署 一.简介 gdb是Linux环境下的代码调试工具 二.部署 1.首先检查系统中有没有安装过,有的话用一下命令卸载gdb旧版本 2.安装依赖 yum -y install gc ...

  5. IO多路复用技术总结

    来源:微信公众号「编程学习基地」 IO 多路复用概述 I/O 多路复用技术是为了解决进程或线程阻塞到某个 I/O 系统调用而出现的技术,使进程不阻塞于某个特定的 I/O 系统调用. 在IO多路复用技术 ...

  6. picoctf_2018_rop chain

    拿到题目就知道要用rop来做 老样子日常检查一下 32位的程序开启了nx和relro保护 将程序放入ida中 一眼就看到了程序中的后门程序 我们逐一分析一下 main vuln get没有对输入字符进 ...

  7. 使用NTP原理进行时间同步

    在一些物联网企业,平台会和嵌入式一起配合进行工作. 有时平台会希望嵌入式这边不使用现成的NTP方案自己去同步时间,而希望以平台下发的时间为准. 此时就有两个方案. 方案1.  平台下发一个时间戳tim ...

  8. List.Sum…统计信息(Power Query 之 M 语言)

    数据源: 任意数据源,一列数值,一列非数值(文本) 目标: 对数值列进行求和等计算,对非数值列进行计数等计算 操作过程: 选取待计算的列>[转换]>[统计信息]>选取   M公式: ...

  9. CF808B Average Sleep Time 题解

    Content 给定 \(n\) 个数 \(a_1,a_2,a_3,...,a_n\),求所有长度为 \(k\) 的连续区间 \([a_1,a_k],[a_2,a_{k+1}],...[a_{n-k+ ...

  10. Linux 磁盘分区和挂载

    目录 Linux 磁盘分区和挂载 windows 下的分区 磁盘管理 相关命令 分区及挂载实现步骤 添加硬盘 分区步骤 步骤 挂载步骤 卸载分区步骤 补充: Linux 磁盘分区和挂载 windows ...