2024蓝桥杯C/C++ B组国赛

P10907 [蓝桥杯 2024 国 B] 蚂蚁开会 - 洛谷

暴力枚举:

把每条线段经过的整数点都求出,然后用map<pair<int, int>, int> 来记录每条线段上的每个点,会被访问多少次

如何求线段上的整点?

分别计算两点x轴坐标和y轴之差,取绝对值后,求出gcd,然后循环把整点为键,其值加一

最后从头到位遍历map,统计大于1的点有多少个

来看代码:

cpp 复制代码
#include <bits/stdc++.h>
#include<unordered_map>
using namespace std;


int gcd(int a, int b)
{
	if (b == 0)
	{
		return a;
	}
	else
	{
		return  gcd(b, a % b);
	}
}

map<pair<int, int>, int>arr;
vector<int>X1;
vector<int>Y1;
vector<int>X2;
vector<int>Y2;
void find_points(int now)
{
	int dx = X2[now] - X1[now];
	int dy = Y2[now] - Y1[now];
	int step = gcd(abs(dx), abs(dy));
	if (step == 0)
	{
		arr[{dx, dy}]++;
	}
	dx /= step;
	dy /= step;
	for (int i = 0; i <= step; i++)
	{
		arr[{X1[now] + i * dx, Y1[now] + i * dy }]++;
	}
}

int main()
{

	int n;
	cin >> n;
	X1 = vector<int>(n);
	Y1 = vector<int>(n);
	X2 = vector<int>(n);
	Y2 = vector<int>(n);
	for (int i = 0; i < n; i++)
	{
		cin >> X1[i] >> Y1[i] >> X2[i] >> Y2[i];
	}
	//每条线段 都把整点求出
	for (int i = 0; i < n; i++)
	{
		find_points(i);
	}
	int ans = 0;
	for (auto &it : arr)
	{
		if (it.second > 1)
		{
			ans++;
		}
	}
	cout << ans;

}
相关推荐
头发还没掉光光1 小时前
Linux网络之IP协议
linux·运维·网络·c++·tcp/ip
燃于AC之乐2 小时前
深入解剖STL Vector:从底层原理到核心接口的灵活运用
开发语言·c++·迭代器·stl·vector·源码分析·底层原理
优雅的潮叭8 小时前
c++ 学习笔记之 chrono库
c++·笔记·学习
星火开发设计9 小时前
C++ 数组:一维数组的定义、遍历与常见操作
java·开发语言·数据结构·c++·学习·数组·知识
月挽清风9 小时前
代码随想录第七天:
数据结构·c++·算法
csdn_aspnet10 小时前
C 语言的优雅回归:从零手造数据结构
c语言·数据结构
点云SLAM10 小时前
C++内存泄漏检测之Windows 专用工具(CRT Debug、Dr.Memory)和Linux 专业工具(ASan 、heaptrack)
linux·c++·windows·asan·dr.memory·c++内存泄漏检测·c++内存管理
浅念-11 小时前
C语言小知识——指针(3)
c语言·开发语言·c++·经验分享·笔记·学习·算法
想放学的刺客12 小时前
单片机嵌入式嵌入式试题(第16期):硬件可靠性设计与复杂状态机架构设计
c语言·stm32·单片机·嵌入式硬件·物联网
无限进步_12 小时前
【C++】大数相加算法详解:从字符串加法到内存布局的思考
开发语言·c++·windows·git·算法·github·visual studio