zoukankan      html  css  js  c++  java
  • Jurisdiction Disenchantment(二维尺取)

    题目描述

    The Super League of Paragons and Champions (SLPC) has been monitoring a plot by a corrupt politician to steal an election. In the past week, the politican has used a mind-control technique to enslave the n representatives responsible for choosing the election’s winner. Luckily, the SLPC has managed to recruit you and hence has access to your power to break mind-control. You are able to break mind-control in an axis-aligned rectangle. Unfortunately, your power comes at a steep cost; you get a headache the next day proportional to the size of the rectangle. You do not even want to risk or think about what would happen if you tried to use your power multiple times in one day.
    You have done your research and you know the position that each representative will be standing when the votes are about to be cast. You need to free enough representatives to prevent the politician from having a majority (strictly more than one-half) vote. What is the area of the smallest axis-aligned rectangle that you can affect to do this?

    输入

    The first line of input contains a single integer T (1 ≤ T ≤ 10), the number of test cases. The first line of each test case contains a single integer n (1 ≤ n ≤ 299, n is odd), the number of representatives. Each of the next n lines of input contains two integers, denoting the x and y coordinates of a representative. It is guaranteed that all coordinates are between −10,000 and +10,000.

    输出

    For each test case, output a single line containing the area of the smallest axis-aligned rectangle containing more than n/2 of the representatives.

    样例输入

    2
    1
    1 1
    3
    0 0
    1 4
    3 2

    样例输出

    0
    4

    提示

    In the first case, a rectangle containing a single point has an area of 0.
    In the second test case, the rectangle needs to include at least two points. There are two smallest possible rectangles; one includes (0, 0) and (1, 4) and the other includes (1, 4) and (3, 2). In either case, the area is 4.

    题意

    有 n 个点,需要用一个矩形框 n/2+1 个点,求矩形最小面积。

    思路

    二维尺取,把 n 个点按 x 降序排序, 枚举 x 的边界,维护在这个边界中 n/2+1 个点的最小矩形面积。

    代码

    #include <bits/stdc++.h>
    using namespace std;
    const int maxn = 300;
    const int inf = 0x7fffffff;
    int T, n;
    
    struct node {
        int x, y;
        void read() {
            scanf("%d%d", &x, &y);
        }
        inline bool operator<(const node &p) {
            return y < p.y;
        }
    } a[maxn], b[maxn];
    
    bool cmp(node a, node b) {
        return a.x < b.x || a.x == b.x && a.y < b.y;
    }
    
    int main() {
        scanf("%d", &T);
        while (T--) {
            scanf("%d", &n);
            for (int i = 1; i <= n; ++i) {
                a[i].read();
                b[i] = a[i];
            }
            sort(a + 1, a + 1 + n, cmp);
            int ans = INT_MAX, m = n / 2 + 1;
            for (int i = 1; i <= n; ++i) {
                for (int j = i; j <= n; ++j) {
                    int lx = a[i].x, rx = a[j].x;
                    int cnt = 0;
                    for (int k = 1; k <= n; ++k) {
                        if (a[k].x < lx || a[k].x > rx) continue;
                        b[++cnt] = a[k];
                    }
                    if (cnt >= m) {
                        sort(b + 1, b + 1 + cnt);
                        for (int k = 1; k <= cnt - m + 1; ++k) {
                            int ly = b[k].y, ry = b[k + m - 1].y;
                            ans = min(ans, (rx - lx) * (ry - ly));
                        }
                    }
                }
            }
            printf("%d
    ", ans);
        }
        return 0;
    }
    
  • 相关阅读:
    线性回归——梯度下降
    Python 实现 KNN(K-近邻)算法
    Python 增加博客园阅读量
    阿里云CentOS安装配置Python3.7及pip3
    OnlineJudge难度与正确度的相关性检验
    jsp、jQuery、servlet交互实现登录功能
    Java Web中提交表单之后跳转到WebContent目录下的子目录里的jsp文件
    python3爬虫——下载unsplash美图到本地
    defer原理、性能、优化
    Python生成器和迭代器
  • 原文地址:https://www.cnblogs.com/acerkoo/p/10927352.html
Copyright © 2011-2022 走看看