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

平面上有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;
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,933评论 18 139
  • 2017年全国统一高考数学试卷(文科)(新课标Ⅰ) 一、选择题:本大题共12小题,每小题5分,共60分。在每小题给...
    高考家庭教育研究阅读 1,015评论 0 3
  • 柠檬的月色,悄悄地攀上了树梢,天空也显得不再那么高远。穿过淡淡的薄雾,融融的月光,如轻幔般地洒下一丝缠绵,像情人间...
    王少云一春来天涯阅读 826评论 1 5
  • 记得宝宝刚上大学那会,智能手机才堪堪是时尚代名词,宝宝有幸因为在外地上大学拥有了一部400块的半智能山寨手机。...
    媚生阅读 531评论 0 50
  • 假期刚刚开始,公婆就开始催促儿子写作业,我个人觉得,可以让他放松两天,好好玩,今年给他报了暑假班,让他学习文化知...
    博硕妈阅读 110评论 0 0