zoukankan      html  css  js  c++  java
  • Problem 3 基站建设 (station.cpp)———2019.10.6

    在此郑重的感激wxyww大佬

    wxyww tql

    【题目描述】
    小 Z 的爸爸是一位通信工程师,他所在的通信公司最近接到了一个新的通
    信工程建设任务,他们需要在 C 城建设一批新的基站。
    C 城的城市规划做得非常好,整个城市被规整地划分为 8 行 8 列共 64 个街
    区,现在已知新基站需要建设在哪些街区,用字符“#”表示,而不需要建设基
    站的街区用“.”表示。
    爸爸告诉小 Z 说,建设基站最耗时的是基站两两之间互相通信的调试,每
    建设一个新的基站,需要确保其与其他已经建好的基站之间能互相通信,若两
    个基站的坐标分别为(x1,y1)和(x2,y2),则调试所需时间大概为 max(|x1-
    x2|,|y1-y2|),而一个基站的总调试时间为与其他已经建好的基站的调试时间
    中的最大值。现在爸爸想考考小 Z,看小 Z 能否计算出如何设计建设基站的顺
    序,使得总的调试时间尽量少?

    【输入格式】
    输入一个 8 行 8 列的矩阵,全部由“#”和“.”组成。
    【输出格式】
    输出一个整数,表示花费的最少时间。
    【样例输入一】
    ........
    ........
    ...#....
    .#......
    .......#
    ........
    ........
    ........
    【样例输出一】
    8
    【样例输入二】
    ##..####
    #####..#
    ..#.#...
    #..##.##
    .#.###.#
    ####.###
    #.#...#.
    ##....#.
    【样例输出二】
    168
    【数据范围】
    设需要建设基站的街区数(即“#”的个数)为 n。

    对于 30%的数据,n≤10;
    对于 60%的数据,n≤20;
    对于 100%的数据,n≤64。

    记忆化搜索诶,,,

    代码

     1 #include<cstdio>
     2 #include<iostream>
     3 #include<algorithm>
     4 #include<cmath>
     5 #include<cstring>
     6 using namespace std;
     7 char mp[11][11];
     8 int f[11][11][11][11],tu[11][11];
     9 int dfs(int x1,int y1,int x2,int y2);
    10 int suan(int x1,int y1,int x2,int y2,int i1,int j1,int i2,int j2);
    11 int jdz(int x) {
    12     return x>0?x:-x;
    13 }
    14 int main() {
    15     freopen("station.in","r",stdin);
    16     freopen("station.out","w",stdout);
    17     memset(f,-1,sizeof f);
    18     for(int i=1; i<=8; i++)
    19         for(int j=1; j<=8; j++)
    20             cin>>mp[i][j];
    21     for(int i=1; i<=8; ++i)
    22         for(int j=1; j<=8; ++j)
    23             tu[i][j] = (mp[i][j]=='#');
    24     /*for(int i=1;i<=8;i++)
    25         {
    26             for(int j=1;j<=8;j++)
    27             cout<<tu[i][j]<<" ";
    28             cout<<"
    ";
    29         }*/
    30     int ans=dfs(1,1,8,8);
    31     cout<<ans;
    32     fclose stdin;
    33     fclose stdout;
    34     return 0;
    35 }
    36 int suan(int x1,int y1,int x2,int y2,int i1,int j1,int i2,int j2) {
    37     int sum=0;
    38     for(int i=i1; i<=i2; i++)
    39         for(int j=j1; j<=j2; j++)
    40             sum+=(tu[i][j])*max(max(jdz(i-x1),jdz(i-x2)),max(jdz(j-y1),jdz(j-y2)));
    41     return sum;
    42 }
    43 int dfs(int x1,int y1,int x2,int y2) {
    44     if(x1>x2||y1>y2)return 0;
    45     if(f[x1][y1][x2][y2]!=-1) return f[x1][y1][x2][y2];
    46     int &res=f[x1][y1][x2][y2];
    47     res=suan(x1,y1,x2,y2,x1,y1,x1,y2)+dfs(x1+1,y1,x2,y2);
    48     res=min(res,suan(x1,y1,x2,y2,x2,y1,x2,y2)+dfs(x1,y1,x2-1,y2));
    49     res=min(res,suan(x1,y1,x2,y2,x1,y1,x2,y1)+dfs(x1,y1+1,x2,y2));
    50     res=min(res,suan(x1,y1,x2,y2,x1,y2,x2,y2)+dfs(x1,y1,x2,y2-1));
    51     return res;
    52 }
    View Code
  • 相关阅读:
    php No input file specified 错误提示
    yii 隐藏index.php
    phpstudy 配置 sqlserver
    xdebug3 配置信息
    composer 更新
    mysql 命令行 导入大型文件
    使用 DBExportDoc V1.0 For MySQL 导出数据库表结构说明文档
    聚合数据接口调用实例
    servlet
    JDBC
  • 原文地址:https://www.cnblogs.com/ydclyq/p/11627538.html
Copyright © 2011-2022 走看看