• HDU 1050 Moving Tables (贪心)


    题意:在一个走廊两边都有对称分布的连续房间,现在有n张桌子需要从a移动到b房间。每次移动需要10分钟,

    但是如果两次移动中需要经过相同的走廊位置,则不能同时进行,需要分开移动。最后求最少需要多长时间移动完所有的桌子。

    析:这应该是一个贪心算法,时间尽量少,但是在一走廊如果相遇,必然是要分开的,所以说,我们只要统计,

    统计在每个走廊的相遇的次数,然后再取最大值,如果最大值都成立了,那么其他的也会成立(想一下,为什么)。

    你想一下,假设有另一个走廊,次数比它少,即使他们的桌子不相同,而其他那些可以在其他时间搬运过去,也不是超过最多次数。

    代码如下:

    #include <cstdio>
    #include <iostream>
    #include <cstring>
    #include <algorithm>
    #include <cmath>
    
    using namespace std;
    const int maxn = 200 + 5;
    int cnt[maxn];
    
    int main(){
        int n, T, a, b;  cin >> T;
        while(T--){
            scanf("%d", &n);
            memset(cnt, 0, sizeof(cnt));
            for(int i = 0; i < n; ++i){
                scanf("%d %d", &a, &b);
                int minn = min(a, b);  ++minn;
                int m = max(a, b);  ++m;
    
                for(int j = minn/2; j <= m/2; ++j)
                    ++cnt[j];
            }
    
            int m = 0;
            for(int i = 0; i < maxn; ++i)
                m = max(m, cnt[i]);
            printf("%d0
    ", m);
        }
        return 0;
    }
    
  • 相关阅读:
    SQLSTATE[HY000] [2054] The server requested authentication method unknown to the client
    Docker 下 nginx + tomcat 负债均衡
    Docker 安装 tomcat 并挂载宿主目录到容器
    Docker 安装 nginx 并挂载宿主目录到容器中
    SpringBoot 常见创建方式
    Java SPI 机制实现解耦
    TCP 粘包问题
    Docker 安装和常用命令
    Docker 安装 ActiveMQ
    INTEL
  • 原文地址:https://www.cnblogs.com/dwtfukgv/p/5555899.html
Copyright © 2020-2023  润新知