题目 参考 题意:给定n和m,分别代表网格规模和点数,接着给出m个二维坐标的点。输入保证这m个点在横、纵坐标不会冲突。现在给定m个点,求在移动过程中不出现横纵坐标碰撞的情况下,最小的移动次数,使得所有点都在正对角线上(即横坐标等于纵坐标)。 题解:把这m个点看成m个边,(a,b)看成a到b的一条边。转化后发现,当一些点在同一个圈中,则它们需要额外一次的移动。可以这么求解最优解:默认是m次移动,每增加一个圈,需要增加一次移动;每多一些不需移动的点(x,x),则减少一次移动。
#include
using namespace std;
const int maxn = 100010;
int n, m;
int f[maxn];
void init() {
for (int i = 1; i
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?