美文网首页
ECNU机试之求最大斜率的两点

ECNU机试之求最大斜率的两点

作者: DaSE_Bee | 来源:发表于2017-10-06 16:38 被阅读0次

平面上有N个点,任意2个点确定一条直线,求出所有这些直线中,斜率最大的那条直线所通过的两个点。(点的编号为1-N,如果有多条直线斜率相等,则输出所有结果,按照点的X轴坐标排序,正序输出。数据中所有点的X轴坐标均不相等)

Input

第1行,一个数N,N为点的数量。(2 <= N <= 50)

第2 - N + 1行:具体N个点的坐标,X Y均为整数(-10^9 <= X,Y <= 10^9)

Output

每行2个数,中间用空格分隔。分别是起点编号和终点编号(起点的X轴坐标<终点的X轴坐标)

Input示例

5
1 2
6 8
4 4
5 4
2 3

Output示例

5 4
6 8

解题思想:将这些坐标点按横坐标排序,求相邻两点的斜率,找出最大斜率后输出直线两点。

参考代码(没有用STL):

#include <iostream>

using std::cin;
using std::cout;
using std::endl;

struct node //存储点的信息
{
    float x,y;
};

int main()
{
    int n=0;
    while(cin>>n)
    {
        node nodes[50];
        float k[50];
        for(int i=0; i<n; i++)
        {
            cin>>nodes[i].x>>nodes[i].y;
        }

        for(int i=n; i>0; i--)
        {
            for(int i=0; i+1<n; i++)
            {
                if(nodes[i].x>nodes[i+1].x)
                {
                    node temp;
                    temp=nodes[i];
                    nodes[i]=nodes[i+1];
                    nodes[i+1]=temp;
                }
            }
        }
        for(int i=0; i+1<n; i++)//求两点之间斜率
        {
            if((nodes[i+1].x-nodes[i].x)==0)//除0
            {
                k[i]=99999;
                continue;
            }
            k[i]=(nodes[i+1].y-nodes[i].y)/(nodes[i+1].x-nodes[i].x);
            cout<<k[i]<<endl;
        }

        float max_a=k[0];
        for(int i=0; i<n-1; i++) //找出最大斜率
        {
            if(max_a<k[i])
            {
                max_a=k[i];
            }
        }

        for(int i=0; i<n; i++)
        {
            if(k[i]==max_a)
            {
                cout<<nodes[i].x<<" "<<nodes[i].y<<endl;//输出结点
                cout<<nodes[i+1].x<<" "<<nodes[i+1].y<<endl;
            }
        }
    }
    return 0;
}

相关文章

  • ECNU机试之求最大斜率的两点

    平面上有N个点,任意2个点确定一条直线,求出所有这些直线中,斜率最大的那条直线所通过的两个点。(点的编号为1-N,...

  • ECNU机试之求中位数

    给N个数,求这些数的中位数。(结果保留小数点一位) Input 第1行,一个数N,N为点的数量。(2 <= N <...

  • ECNU机试之判断“东西越贵越好”的命题

    由于题目比较长,并且时间已久,我只记得题目大概的意思:给出N个商品的价格和质量,判断“东西越贵越好”这个命题是否正...

  • 7297T一道椭圆背景下的三角形面积最大值问题

    昨天的题目是在弦过定点,求三角形面积最大值,今天的题目是弦的斜率为定值,求三角形面积最大值。

  • 数学题

    已知A是椭圆E:的左顶点,斜率为的直线交E于A,M两点,点N在E上,MANA.(1)当|AM|=|AN|时,求的面积.

  • 直线

    求直线方程 过点(a,b)斜率不存在的直线方程为x=a 过点(a,b)斜率为0的直线方程为y=b

  • ECNU机试之判断字符串是否存在AB、BA子串

    输入字符串,判断是否同时存在AB、BA的子串,输出yes/no。 Input 输入只含有'A'、'B'字符的字符串...

  • 导数的概念2

    解析几何里面如何求斜率 你还记得学数学时第一次听说斜率是什么时候吗?斜率一词是在学习正比例函数时出现的,看来我们和...

  • 梯度下降算法及其他算法的介绍

    1. 为什么梯度方向是斜率最大的方向?[1] (1-1)斜率最大的方向命名为梯度方向 (1-2)二维函数f...

  • Leetcode.149.Max Points on a Lin

    题目 二维坐标上给定多个点, 输出最多有多少个点在一条直线上. 思路 遍历计算两点的斜率, 运用gcd记录斜率, ...

网友评论

      本文标题:ECNU机试之求最大斜率的两点

      本文链接:https://www.haomeiwen.com/subject/vwhryxtx.html