zoukankan      html  css  js  c++  java
  • L

    L - Black-and-White Cube
    Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u
    Submit Status
    Appoint description: 

    Description

    You are given a cube of size k × k × k, which consists of unit cubes. Two unit cubes are considered neighbouring, if they have common face.

    Your task is to paint each of k3 unit cubes one of two colours (black or white), so that the following conditions must be satisfied:

    • each white cube has exactly 2 neighbouring cubes of white color;
    • each black cube has exactly 2 neighbouring cubes of black color.

    Input

    The first line contains integer k(1 ≤ k ≤ 100), which is size of the cube.

    Output

    Print -1 if there is no solution. Otherwise, print the required painting of the cube consequently by layers. Print a k × k matrix in the firstk lines, showing how the first layer of the cube should be painted. In the following k lines print a k × k matrix — the way the second layer should be painted. And so on to the last k-th layer. Note that orientation of the cube in the space does not matter.

    Mark a white unit cube with symbol "w" and a black one with "b". Use the format of output data, given in the test samples. You may print extra empty lines, they will be ignored.

    Sample Input

    Input
    1
    Output
    -1
    Input
    2
    Output
    bb
    ww

    bb
    ww
     

    int main() { //freopen("in.txt","r",stdin); int k; while(cin>>k) { if(k%2) { cout<<-1<<endl; continue; } repf(i,1,k/2)//i layout { if(i%2 == 0) { repf(j,1,k)//j column { repf(a,1,k/2) { if(j%2) { if(a%2) cout<<"bb"; else cout<<"ww"; }else { if(a%2==0) cout<<"bb"; else cout<<"ww"; } } cout<<endl; } cout<<endl; repf(j,1,k)//j column { repf(a,1,k/2) { if(j%2) { if(a%2) cout<<"bb"; else cout<<"ww"; }else { if(a%2==0) cout<<"bb"; else cout<<"ww"; } } cout<<endl; } cout<<endl; }else { repf(j,1,k) { repf(a,1,k/2) { if(j%2==0) { if(a%2) cout<<"bb"; else cout<<"ww"; }else { if(a%2==0) cout<<"bb"; else cout<<"ww"; } } cout<<endl; } cout<<endl; repf(j,1,k) { repf(a,1,k/2) { if(j%2==0) { if(a%2) cout<<"bb"; else cout<<"ww"; }else { if(a%2==0) cout<<"bb"; else cout<<"ww"; } } cout<<endl; } cout<<endl; } } } return 0; }
  • 相关阅读:
    制作Windows Server 2008安装启动U盘
    wireshark教程(一)
    TCPdump抓包命令详解
    ATM交换机 和普通交换机区别
    胖ap和瘦ap区别
    酒店网络非常常见故障一例
    JQuery EasyUI DataGrid动态合并(标题)单元) 一
    字典表左右选择
    treegrid-dnd.js
    MySQL开发规范
  • 原文地址:https://www.cnblogs.com/DreamHighWithMe/p/3431266.html
Copyright © 2011-2022 走看看