蓝桥 算法训练 共线(C++)

问题描述

  给定2维平面上n个整点的坐标,一条直线最多能过几个点?

输入格式

  第一行一个整数n表示点的个数
  以下n行,每行2个整数分别表示每个点的x,y坐标。

输出格式

  输出一个整数表示答案。

样例输入

5
0 0
1 1
2 2
0 3
2 3

样例输出

3

数据规模和约定

  n<=1500,数据保证不会存在2个相同的点。
  点坐标在int范围内


题目链接:“蓝桥杯”练习系统

解析:用哈希表关键字与键值映射即可,斜率当关键字,每有一个点在此直线上不断加一即可。话不多说,直接上代码,代码附注释。

#include<iostream>
#include<utility>
#include<map>

using namespace std;

pair<int,int> a[2000];//输入二维坐标,用pair或结构体
int n,maxx;

int main(){
	cin>>n;
	for(int i=0;i<n;i++){
		cin>>a[i].first>>a[i].second;//输入位置
	}
	map<double,int> p;//用map映射
	for(int i=0;i<n;i++){//始点
		for(int j=i+1;j<n;j++){//终点
			double k;//斜率
			k=double(a[i].second-a[j].second)/(a[i].first-a[j].first);//强转为double,否则数据会四舍五入
			if(p[k]==0){//如果此次斜率是第一次出现,说明两点构成一条直线,点数为2,需要多加一次
				p[k]++;
			}
			p[k]++;//如果存在了那就再此基础上加一即可
			maxx=max(p[k],maxx);//寻找最大值
		}
		p.erase(p.begin(),p.end());//暴力枚举,若不清空,会影响下一个始点的计算
		//我们是先固定起点,再遍历终点,求斜率
		//若有三个点构成一条直线,第一次固定第一个点为始点,终点遍历后面两个点,此时为点数3
		//若不清空继续遍历,第二个点为始点,第三个点为终点,p[k]++还会继续,变为4,重复计算,所以清空
	}
	cout<<maxx<<endl;
	return 0;
}

此题是本人的思路,小白一枚,若有更好的方法,欢迎各位大佬讨论。

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

摆烂小白敲代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值