【牛客IOI周赛26-普及组】A-平行四边形

简介: 【牛客IOI周赛26-普及组】A-平行四边形

链接:https://ac.nowcoder.com/acm/contest/11233/A

来源:牛客网

A-平行四边形

题目描述:

给出四个点,判断是否构成不退化的平行四边形。(退化指存在三点共线)

输入描述:

本题有多组数据,第一行是数据组数 T。

每组数据输入四行,每行两个整数,分别为x1,y1,x2,y2,x3,y3,x4,y4,描述四个点的坐标(x1,y1),(x2,y2),(x3,y3),(x4,y4)

输出描述:

对每组数据输出一行一个字符串 YES 或者 NO(全部大写),分别表示是或不是平行四边形。

输入:

4
0 0 
1 1 
0 1 
1 0
0 1 
1 1 
1 0 
0 0
0 0 
1 1 
2 2 
3 3
4 2 
5 3 
6 6 
9 -10

输出:

YES
YES
NO
NO

说明:

样例的第 1,2 组数据中的点组成了正方形,自然是平行四边形。

第三组数据四个点共线,不是平行四边形。最后一组数据四个点不组成平行四边形。

备注:

对于 50% 的数据,不存在三点共线。

对于 100%的数据,1≤T≤10 ^ 4,∣xi∣∣yi∣ ≤ 10 ^ 9。


题解

我们都知道

平行于X轴的直线的斜率为零,平行于Y轴的直线的斜率不存在。

而对于过两个已知点(x1,y1)和(x2,y2)的直线,若x1≠x2,则该直线的斜率为k=(y1-y2)/(x1-x2)。

根据平行四边形的判定条件:

两组对边分别平行的四边形是平行四边形

所以判断

(x1,y1)(x2,y2)两点之间的斜率是否与(x3,y3)(x4,y4)之间的斜率相等

(x1,y1)(x3,y3)两点之间的斜率是否与(x2,y2)(x4,y4)之间的斜率相等

(x1,y1)(x4,y4)两点之间的斜率是否与(x2,y2)(x3,y3)之间的斜率相等

这3个条件,只要有两种条件成立(即1,2或者1,3),则该四边形是平行四边形

坐标的两种情况(如图)

代码:

#include <iostream>
using namespace std;
int x1,y1,x2,y2,x3,y3,x4,y4;
bool ComparisonOfTheSlope()
{
    int count=0;
    if((y1-y2)*(x3-x4)==(y3-y4)*(x1-x2))
        count++;
    if((y1-y3)*(x2-x4)==(y2-y4)*(x1-x3))
        count++;
    if((y1-y4)*(x2-x3)==(y2-y3)*(x1-x4))
        count++;
    if(count==2)
        return 1;//该四边形是平行四边形
    else
        return 0;//该四边形不是平行四边形
}
int main()
{
    int T;
    cin>>T;
    for(int i=1;i<=T;i++)
    {
        cin>>x1>>y1>>x2>>y2>>x3>>y3>>x4>>y4;
        if(ComparisonOfTheSlope())
            cout<<"YES"<<endl;
        else
            cout<<"NO"<<endl;
    }
    return 0;
}


目录
相关文章
|
Java C++ Python
快讯:LeetCode中国正式上线《剑指Offer》题目,刷题真方便了!
近日,LeetCode中国[1]上线了一个全新的分类模块 LCOF “剑指 Offer[2]”。
4500 0
快讯:LeetCode中国正式上线《剑指Offer》题目,刷题真方便了!
|
10天前
【洛谷 P1046】[NOIP2005 普及组] 陶陶摘苹果 题解(比较)
`NOIP2005普及组`编程题《陶陶摘苹果》:陶陶有10个高度在100-200cm的苹果要摘,手触及最大高度+30cm板凳后能摘到的苹果数。输入10个苹果高度和她的最大触及高度,输出可摘苹果数。样例输入:10个苹果高度和110cm触及高度,输出5,表示能摘5个。代码通过逐个比较苹果高度实现统计。
10 0
|
10天前
|
C++
【洛谷 P1047】[NOIP2005 普及组] 校门外的树 题解(位集合)
**NOIP2005普及组问题:**给定长度为$l$的马路,上面等距种植着树,需移除位于建造地铁区域的树。输入包含马路长度和区域数,以及各区域起止点,输出移树后剩余树的数量。样例输入:$l=500$, $m=3$,输出:$298$。$20\%$数据无区域重合,$1 \leq l \leq 10^4$,$1 \leq m \leq 100$。解决方案利用位集合(bitset)表示树的状态,遍历区域将树设为0,最后统计1的数量。AC代码使用C++实现。
5 0
|
10天前
|
C++
【洛谷 P1085】[NOIP2004 普及组] 不高兴的津津 题解(打擂台法)
**NOIP2004 普及组问题:津津的日程检查。津津每日上课时间若超8小时会不高兴。输入7行代表一周课程,输出最不高兴的日期(1-7)或0。示例输入/输出:5 3 6 2 7 2 5 3 5 4 0 4 0 6 -&gt; 3。使用C++代码通过遍历计算最大上课时间并找到对应日期。**
10 0
|
10天前
【洛谷 P1909】[NOIP2016 普及组] 买铅笔 题解(打擂台法)
**摘要:** P老师需买$n$支铅笔作礼物,商店有3种包装(数量、价格不等),不能拆包。目标是最少花费。输入包括$n$和每种包装的详情,输出最小花费。样例展示最优选择过程。代码使用打擂台法求解,读入$n$和包装信息,计算每种包装的最小花费,取最小值输出。
5 0
|
2月前
|
测试技术 C语言
第十四届蓝桥杯B组第一期模拟题
第十四届蓝桥杯B组第一期模拟题
36 0
|
12月前
|
算法 测试技术 C++
第十一届蓝桥杯第三场软件类省赛 C++ B组 题解(一)
第十一届蓝桥杯第三场软件类省赛 C++ B组 题解
|
12月前
|
算法 测试技术 C++
第十一届蓝桥杯第三场软件类省赛 C++ B组 题解(二)
第十一届蓝桥杯第三场软件类省赛 C++ B组 题解
118 0
|
12月前
|
机器学习/深度学习 测试技术 C++
看看去年蓝桥考了什么,第十三届蓝桥杯省赛(C/C++ 大学B组)题解(二)
看看去年蓝桥考了什么,第十三届蓝桥杯省赛(C/C++ 大学B组)题解
128 0
|
12月前
|
存储 人工智能 测试技术
看看去年蓝桥考了什么,第十三届蓝桥杯省赛(C/C++ 大学B组)题解(一)
看看去年蓝桥考了什么,第十三届蓝桥杯省赛(C/C++ 大学B组)题解
183 0