题意:
给你n个点,让你找一个最小的正方形去覆盖所有点。
思路:
给你n个点,让你找一个最小的正方形去覆盖所有点。
思路:
想一下,如果题目中规定正方形必须和x轴平行,那么我们是不是直接找到最大的x差和最大的y差取最大就行了,但是这个题目没说平行,那么我们就旋转这个正方形,因为是凸性(或者凹性)用三分去枚举正方形的角度[0,PI/2],然后缩小范围,知道找到答案。公式是
nowx = x * cos(du) - y * sin(d) nowy = x * sin(du) + y *cos(d)
#include<stdio.h>
#include<math.h>
#define N 50
#define eps 0.000001
double PI = acos(-1.0);
typedef struct
{
double x ,y;
}NODE;
NODE node[N];
double maxx(double x ,double y)
{
return x > y ? x : y;
}
double minn(double x ,double y