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 C. Colored Rooks 構造 (Codeforces Round #518 (Div. 2) )
- codeforces 1438D,思路非常非常巧妙的構造題
- Parquet.Net: 將 Apache Parquet 移植到 .NETApache
- Codeforces 1749E Cactus Wall 題解 [ 紫 ] [ 01 BFS ] [ 圖論建模 ] [ 構造 ] [ adhoc ]圖論
- Spark Parquet詳解Spark
- Java--構造器和構造方法Java構造方法
- C++ 建構函式實戰指南:預設構造、帶引數構造、複製構造與移動構造C++函式
- 建立Parquet結果表
- SparkSQL與Hive metastore ParquetSparkSQLHiveAST
- 構造方法構造方法
- 構造器
- 構造點,線結構
- 構造有理數~
- CF 構造題
- java構造器Java
- AUTOCAD——構造線
- 構造方法20201202構造方法
- 日曆(設計構造器與預設構造器)
- 【軟體構造課程相關】幻方及其構造(上)
- 構造程式碼塊
- 初等雙射構造
- 十七、物件的構造物件
- 貪心、構造合集
- 軟體構造八
- LeetCode 492[構造矩形]LeetCode
- 14.構造器
- 【lombok】@NoArgsConstructor/@RequirArgsConstructor/@AllArgsConstructor - 生成無參構造器,指定引數構造器或包含所有引數的構造器LombokStructUI
- Flink生成Parquet格式檔案實戰
- 解析Pyspark如何讀取parquet資料Spark
- 區分:派生類指定基類建構函式、繼承構造、委託構造函式繼承
- 構造和解構函式呼叫順序函式
- 構造方法-2019/2/25構造方法
- iOS提供指定構造器iOS
- Swift-構造過程Swift
- ARC149C (構造)
- Bob in Wonderland(思維+構造)
- 外測度的構造
- Java構造器 小白版Java