• [模拟]无线网络发射器选址


    无线网络发射器选址

    题目描述

        随着智能手机的日益普及,人们对无线网的需求日益增大。某城市决定对城市内的公共场所覆盖无线网。
        假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻的平行街道之间的距离都是恒定值 1 。东西向街道从北到南依次编号为0,1,2…128 , 南北向街道从西到东依次编号为0,1,2…128 。
        东西向街道和南北向街道相交形成路口,规定编号为x 的南北向街道和编号为y 的东西向街道形成的路口的坐标是(x ,  y )。 在 某 些 路 口 存 在 一 定 数 量 的 公 共 场 所 。 
        由于政府财政问题,只能安装一个大型无线网络发射器。该无线网络发射器的传播范围是一个以该点为中心,边长为2*d 的正方形。传播范围包括正方形边界。
        例如下图是一个d   = 1 的无线网络发射器的覆盖范围示意图。

        现在政府有关部门准备安装一个传播参数为d 的无线网络发射器,希望你帮助他们在城市内找出合适的安装地点,使得覆盖的公共场所最多。

    输入

    输入文件名为wireless.in。
    第一行包含一个整数d ,表示无线网络发射器的传播距离。
    第二行包含一个整数n ,表示有公共场所的路口数目。
    接下来n 行,每行给出三个整数x ,  y ,  k ,  中间用一个空格隔开,分别代表路口的坐标( x ,  y )
    以及该路口公共场所的数量。同一坐标只会给出一次。 
     

    输出

    输出文件名为wireless.out 。
    输出一行,包含两个整数,用一个空格隔开,分别表示能覆盖最多公共场所的安装地点
    方案数,以及能覆盖的最多公共场所的数量。

    样例输入

    1  
    2  
    4 4 10  
    6 6 20

    样例输出

    1 30

    提示

    【数据说明】

    对于100%的数据,1  ≤   d   ≤   2 0 ,1  ≤   n   ≤   20,  0  ≤   x   ≤   128 , 0  ≤   y   ≤   128 , 0  <  k   ≤  1 ,000,000 。

    纯纯的模拟呐~

    代码:

     1 //太水啦QAQ
     2 //不在本机编译的都死了QAQQ
     3 #include<algorithm>
     4 #include<cstdio>
     5 #include<cstring>
     6 #include<queue>
     7 
     8 const int Maxv = 130; 
     9 int d, n, x, y, k, mp[Maxv][Maxv], maxn, tot;
    10 std::queue<int> dl;
    11 
    12 int read(){
    13     int x = 0, f = 1; 
    14     char ch = getchar(); 
    15     while (ch < '0' || ch > '9') {
    16         if (ch == '-') {
    17             f = -1; 
    18         }
    19         ch = getchar(); 
    20     }
    21     while (ch >= '0' && ch <= '9') {
    22         x = x * 10 + ch - '0';
    23         ch = getchar();  
    24     }
    25     return x * f; 
    26 }
    27 
    28 int main(){
    29     scanf("%d %d", &d, &n);
    30     for (int i = 1;i <= n;i++) {
    31         x = read(); 
    32         y = read(); 
    33         k = read(); 
    34         mp[x][y] = k;
    35     }
    36     for (int i = 0; i <= 128; i++) {
    37         for (int j = 0; j <= 128; j++) {
    38             int ans = 0;
    39             for (int o = std::max(0,i - d); o <= std::min(128, i + d); o++) {
    40                 for (int p = std::max(0,j - d); p <= std::min(128,j + d); p++) {
    41                     ans += mp[o][p];
    42                 }
    43             }
    44             maxn = std::max(maxn,ans);
    45             if (ans == maxn) {
    46                 dl.push(ans); 
    47             }
    48         }
    49     }
    50     while (!dl.empty()) {
    51         if (dl.front() == maxn) {
    52             tot++;
    53         }
    54         dl.pop();
    55     }
    56     printf("%d %d
    ", tot, maxn);
    57     return 0;
    58 }
  • 相关阅读:
    Set和Map
    将博客搬至CSDN
    (转)VS制作安装包
    C#俄罗斯方块实现思路及源码
    ASP.NET网站部署过程
    2016百度之星资格赛总结
    数据库编程常见错误总结
    (转)Android 如何全局获取Context
    Android数据文件存储
    关于工程文档中图表的使用
  • 原文地址:https://www.cnblogs.com/GldHkkowo/p/8920404.html
Copyright © 2020-2023  润新知