评测方式:文本比较

题目描述

这是一个数三角的游戏。长度为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. Spring MVC入门(一)—— RestTemplate组件

    ClientHttpRequestFactory 它是个函数式接口,用于根据URI和HttpMethod创建出一个ClientHttpRequest来发送请求~ ClientHttpRequest它代 ...

  2. typora使用快捷键

    1. Ctrl+/ 切换源码模式2. ```css 选择语言 回车.4. `code` ctrl+shit+` 5. # 1号标题 ctrl+1 ### 3号标题 ctrl+3 ######6号标题 ...

  3. 【Linux】【Services】【nfs】nfs安装与配置

    1. 概念 1.1. NFS:Network File System,传统意义上,文件系统在内核中实现. 1.2. RPC:Remote Procedure Call protocol,远程过程调用, ...

  4. 【Linux】【Basis】磁盘分区

    1. Linux磁盘及文件系统管理 1.1. 基本概念: 1.1.1. 磁盘接口类型: IDE(ata):并口,133MB/s,设备/dev/hd[a-z] SCSI:并口,Ultrascsi320, ...

  5. linux 磁盘满了,vim 编辑文件时无法保存

    早上来发现 redis 不能用,报 MISCONF Redis is configured to save RDB snapshots, but it is currently not able to ...

  6. excel数据导入mySql数据库

    1.将excel数据保存好 2.打开数据库,在表上点击右键,选择导入向导 3.点击下图中红色部门,点击下一步 4.选择excel文件的位置,下方的表空间内,会出现excel中的sheet页,选择要导入 ...

  7. Linux目录结构和基础命令

    Linux目录和基础命令 目录 Linux目录和基础命令 1 Linux目录结构 1.1 Linux文件名命令要求 1.2 文件的类型 2. 基础命令 2.1 ls 2.2 cd和pwd 2.3 命令 ...

  8. 【已解决】关于echarts的splitArea分割区域背景闪烁问题

    (x轴)使用时间类型(type: "time"),并且x轴使用splitArea划分后使用color属性设定分割区域颜色.        同时使用dataZoom设置区域缩放,在局 ...

  9. Numpy.frompyfunc()将计算单个值的函数转化为计算数组中每个元素的函数

    Numpy.frompyfunc()将计算单个值的函数转化为计算数组中每个元素的函数 不再通过遍历,对数组中的元素进行运算,利用frompyfunc()将计算单个值的函数转化为计算数组中每个元素的函数 ...

  10. Unhandled Exception: FormatException: Unexpected character

    错误原因 json格式不正确,检查:是否加了注释.最后一个是否加了逗号... 正确格式 { "name": "shellon", "age" ...