zoukankan      html  css  js  c++  java
  • Codeforces Round #551 (Div. 2)B. Serval and Toy Bricks

    B. Serval and Toy Bricks
    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Luckily, Serval got onto the right bus, and he came to the kindergarten on time. After coming to kindergarten, he found the toy bricks very funny.

    He has a special interest to create difficult problems for others to solve. This time, with many 1×1×11×1×1 toy bricks, he builds up a 3-dimensional object. We can describe this object with a n×mn×m matrix, such that in each cell (i,j), there are hi,jhi,j bricks standing on the top of each other.

    However, Serval doesn't give you any hi,j and just give you the front view, left view, and the top view of this object, and he is now asking you to restore the object. Note that in the front view, there are mm columns, and in the ii -th of them, the height is the maximum of h1,i,h2,i,,hn,ih1,i,h2,i,…,hn,i . It is similar for the left view, where there are nn columns. And in the top view, there is an n×mn×m matrix ti,jti,j , where ti,jti,j is 00 or 11 . If ti,jti,j equals 11 , that means hi,j>0hi,j>0 , otherwise, hi,j=0hi,j=0 .

    However, Serval is very lonely because others are bored about his unsolvable problems before, and refused to solve this one, although this time he promises there will be at least one object satisfying all the views. As his best friend, can you have a try?

    Input

    The first line contains three positive space-separated integers n,m,hn,m,h (1n,m,h1001≤n,m,h≤100 ) — the length, width and height.

    The second line contains mm non-negative space-separated integers a1,a2,,ama1,a2,…,am , where aiai is the height in the ii -th column from left to right of the front view (0aih0≤ai≤h ).

    The third line contains nn non-negative space-separated integers b1,b2,,bnb1,b2,…,bn (0bjh0≤bj≤h ), where bjbj is the height in the jj -th column from left to right of the left view.

    Each of the following nn lines contains mm numbers, each is 00 or 11 , representing the top view, where jj -th number of ii -th row is 11 if hi,j>0hi,j>0 , and 00 otherwise.

    It is guaranteed that there is at least one structure satisfying the input.

    Output

    Output nn lines, each of them contains mm integers, the jj -th number in the ii -th line should be equal to the height in the corresponding position of the top view. If there are several objects satisfying the views, output any one of them.

    Examples
    Input
     
    3 7 3
    2 3 0 0 2 0 1
    2 1 3
    1 0 0 0 1 0 0
    0 0 0 0 0 0 1
    1 1 0 0 0 0 0
    
    Output
     
    1 0 0 0 2 0 0
    0 0 0 0 0 0 1
    2 3 0 0 0 0 0
    
    Input
     
    4 5 5
    3 5 2 0 4
    4 2 5 4
    0 0 0 0 1
    1 0 1 0 0
    0 1 0 0 0
    1 1 1 0 0
    
    Output
     
    0 0 0 0 4
    1 0 2 0 0
    0 5 0 0 0
    3 4 1 0 0
    
    
    
    
    
    
    

    
    
    
    

    解题思路:这道题就是给你正视图,侧视图,俯视图,让你恢复它的原状;
    实际上这个用多组解;用贪心即可,每次取最小;
    代码如下:
     1 #include<iostream>
     2 using namespace std;
     3 
     4 int row , col , height ;
     5 int c[105];
     6 int r[105];
     7 int G[105][105];
     8 int main()
     9 {
    10     cin>>row>>col>>height;
    11     for(int i = 0 ; i < col ;i++)
    12     {
    13         cin>>c[i];
    14     }
    15     for(int i = 0 ; i < row ;i++)
    16     {
    17         cin>>r[i];
    18      } 
    19      
    20      for(int i = 0 ; i < row ;i++)
    21      {
    22          for(int j = 0 ; j < col ;j++)
    23          {
    24              cin>>G[i][j];
    25              if(G[i][j]==1)
    26              {
    27                  if(c[j]<=r[i]) //不断取行和列交接处的较小者
    28                  {
    29                      G[i][j] = c[j];
    30                  }else
    31                  G[i][j] = r[i];
    32              }
    33          }
    34      }
    35 
    36      for(int i =  0; i < row ;i++)
    37      {
    38          for(int j = 0 ; j < col ;j++)
    39          {
    40              cout<<G[i][j];
    41              (j==col-1)?cout<<"":cout<<" ";//格式
    42          }
    43          cout<<endl;
    44      }
    45      return 0 ;
    46 }


  • 相关阅读:
    C#中Invoke的用法(转)
    C#中Thread.IsBackground 属性
    127.0.0.1是什么地址?
    C# Socket服务器端如何判断客户端断开求解
    C#中线程间操作无效: 从不是创建控件 txtBOX 的线程访问它。
    C#多线程学习之如何操纵一个线程
    利用TCP协议,实现基于Socket的小聊天程序(初级版)
    进程与线程的一个简单解释
    javascript修改css样式表
    html根据下拉框选中的值修改背景颜色
  • 原文地址:https://www.cnblogs.com/yewanting/p/10708118.html
Copyright © 2011-2022 走看看