CodeForces - 26C Parquet【構造】
題目連結:https://codeforces.com/contest/26/problem/C
#include <iostream>
#include <cctype>
using namespace std;
static const int MAXN=100+10;
char g[MAXN][MAXN];
int n,m,a,b,c;
int main()
{
scanf("%d%d%d%d%d",&n,&m,&a,&b,&c);
bool flag=true;
if(n%2 && m%2) flag=false;
else if(n%2)
{
for(int i=1;i<=m;i+=2)
if(a) a--,g[n][i]=g[n][i+1]='1';
else flag=false;
for(int i=1;i<=n-1;i+=2)
for(int j=1;j<=m;j+=2)
if(c) c--,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='3';
else if(a>1) a-=2,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='1';
else if(b>1) b-=2,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='2';
else flag=false;
}
else if(m%2)
{
for(int i=1;i<=n;i+=2)
if(b) b--,g[i][m]=g[i+1][m]='2';
else flag=false;
for(int i=1;i<=n;i+=2)
for(int j=1;j<=m-1;j+=2)
if(c) c--,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='3';
else if(a>1) a-=2,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='1';
else if(b>1) b-=2,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='2';
else flag=false;
}
else
{
for(int i=1;i<=n;i+=2)
for(int j=1;j<=m;j+=2)
if(c) c--,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='3';
else if(a>1) a-=2,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='1';
else if(b>1) b-=2,g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]='2';
else flag=false;
}
if(flag)
{
for(int i=0;i<=m+1;i++) g[0][i]=g[n+1][i]='i';
for(int i=1;i<=n;i++) g[i][0]=g[i][m+1]='i';
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
bool vis[10]={0};
if(g[i][j]=='1')
{
if(isalpha(g[i-1][j])) vis[g[i-1][j]-'a']=true;
if(isalpha(g[i-1][j+1])) vis[g[i-1][j+1]-'a']=true;
if(isalpha(g[i][j-1])) vis[g[i][j-1]-'a']=true;
if(isalpha(g[i][j+2])) vis[g[i][j+2]-'a']=true;
if(isalpha(g[i+1][j])) vis[g[i+1][j]-'a']=true;
if(isalpha(g[i+1][j+1])) vis[g[i+1][j+1]-'a']=true;
for(int k=0;k<10;k++)
if(!vis[k])
{
g[i][j]=g[i][j+1]=k+'a';
break;
}
}
else if(g[i][j]=='2')
{
if(isalpha(g[i-1][j])) vis[g[i-1][j]-'a']=true;
if(isalpha(g[i][j-1])) vis[g[i][j-1]-'a']=true;
if(isalpha(g[i][j+1])) vis[g[i][j+1]-'a']=true;
if(isalpha(g[i+1][j-1])) vis[g[i+1][j-1]-'a']=true;
if(isalpha(g[i+1][j+1])) vis[g[i+1][j+1]-'a']=true;
if(isalpha(g[i+2][j])) vis[g[i+2][j]-'a']=true;
for(int k=0;k<10;k++)
if(!vis[k])
{
g[i][j]=g[i+1][j]=k+'a';
break;
}
}
else if(g[i][j]=='3')
{
if(isalpha(g[i-1][j])) vis[g[i-1][j]-'a']=true;
if(isalpha(g[i-1][j+1])) vis[g[i-1][j+1]-'a']=true;
if(isalpha(g[i][j-1])) vis[g[i][j-1]-'a']=true;
if(isalpha(g[i][j+2])) vis[g[i][j+2]-'a']=true;
if(isalpha(g[i+1][j-1])) vis[g[i+1][j-1]-'a']=true;
if(isalpha(g[i+1][j+2])) vis[g[i+1][j+2]-'a']=true;
if(isalpha(g[i+2][j])) vis[g[i+2][j]-'a']=true;
if(isalpha(g[i+2][j+1])) vis[g[i+2][j+1]-'a']=true;
for(int k=0;k<10;k++)
if(!vis[k])
{
g[i][j]=g[i+1][j]=g[i][j+1]=g[i+1][j+1]=k+'a';
break;
}
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
printf("%c",g[i][j]);
printf("\n");
}
}
else puts("IMPOSSIBLE");
return 0;
}
相關文章
- Codeforces 549B. Looksery Party[構造]
- Codeforces 410C.Team[構造]
- Codeforces C. Colored Rooks 構造 (Codeforces Round #518 (Div. 2) )
- Codeforces 715A. Plus and Square Root[數學構造]
- Codeforces Gym 100425H H - Football Bets 構造
- codeforces 1438D,思路非常非常巧妙的構造題
- Parquet.Net: 將 Apache Parquet 移植到 .NETApache
- 從NSM到Parquet:儲存結構的衍化
- Spark Parquet詳解Spark
- Java--構造器和構造方法Java構造方法
- SparkSQL與Hive metastore ParquetSparkSQLHiveAST
- C++ 建構函式實戰指南:預設構造、帶引數構造、複製構造與移動構造C++函式
- Codeforces 1749E Cactus Wall 題解 [ 紫 ] [ 01 BFS ] [ 圖論建模 ] [ 構造 ] [ adhoc ]圖論
- 構造方法構造方法
- 構造器
- 構造點,線結構
- CSS構造塊CSS
- Redis鎖構造Redis
- java構造器Java
- CF 構造題
- 靜態程式碼塊、構造程式碼塊、構造方法構造方法
- C#例項構造器,型別構造器 -筆記型別筆記
- 【軟體構造課程相關】幻方及其構造(上)
- 十七、物件的構造物件
- 構造程式碼塊
- C++ 構造方法C++構造方法
- 貪心、構造合集
- 軟體構造八
- 初等雙射構造
- 解析Pyspark如何讀取parquet資料Spark
- 區分:派生類指定基類建構函式、繼承構造、委託構造函式繼承
- 構造和解構函式呼叫順序函式
- Swift-構造過程Swift
- 構造二叉樹二叉樹
- iOS提供指定構造器iOS
- 深入Android —— 介面構造Android
- C# List構造TreeViewC#View
- nginx 緩衝區構造Nginx