POJ-2996

#include <algorithm>
#include <cstring>
#include <cstdio>
#include <iostream>
#include <utility>
#include <vector>
#include <cmath>
#define fi first
#define sc second
using namespace std;
typedef long long LL;
typedef pair<int,int>PII;
const int N=110;
char g[N][N];
int ne[6]={'K','Q','R','B','N','P'};
void solve()
{
	vector <PII>v[1000];
	for(int i=0;i<=16;i++)scanf("%s",&g[i]);
	int hh=1;
	for(int i=15;i>=1;i-=2)
	{
		int x=2,tt=0;
		for(int j=x;j<=30;j+=4)
		{
			tt++;
			if(g[i][j]=='.'||g[i][j]==':')continue;
			v[g[i][j]].push_back({tt,hh});
		}
		hh++;
	}
	// k q r b n p
	printf("White: ");
	bool flag=false;

	for(int i=0;i<6;i++)
	{
		int x=ne[i];
		if(v[x].size()==0)continue;
		if(!flag)
		{
			PII  y=v[x][0];
			//printf("%c%c%d",x,y.fi+'a'-1,8-y.sc+1);
			if(x!='P')printf("%c%c%d",x,y.fi+'a'-1,y.sc);
			else printf(",%c%d",y.fi+'a'-1,y.sc);
		}
		//for(auto y:v[x])
		for(int j=0;j<v[x].size();j++)
		{
			if(!flag)
			{
				flag=true;continue;
			}
			if(x!='P')printf(",%c%c%d",x,v[x][j].fi+'a'-1,v[x][j].sc);
			else printf(",%c%d",v[x][j].fi+'a'-1,v[x][j].sc);
		}
	}
	puts("");printf("Black: ");
	flag=false;
	hh=1;
	for(int i=0;i<200;i++)v[i].clear();
	for(int i=1;i<=16;i+=2)
	{

		int x=2,tt=0;
		for(int j=x;j<=30;j+=4)
		{
			tt++;
			if(g[i][j]=='.'||g[i][j]==':')continue;
			v[g[i][j]].push_back({tt,hh});
		}
		hh++;
	}
	for(int i=0;i<6;i++)
	{
		int x=ne[i]+32;
		if(v[x].size()==0)continue;
		if(!flag)
		{
			PII  y=v[x][0];
			//printf("%c%c%d",x,y.fi+'a'-1,8-y.sc+1);
			if(x!='P'+32)printf("%c%c%d",ne[i],y.fi+'a'-1,8-y.sc+1);
			else printf(",%c%d",y.fi+'a'-1,8-y.sc+1);
		}
		for(int j=0;j<v[x].size();j++)
		{
			if(!flag)
			{
				flag=true;continue;
			}
			if(x!='P'+32)printf(",%c%c%d",ne[i],v[x][j].fi+'a'-1,8-v[x][j].sc+1);
			else printf(",%c%d",v[x][j].fi+'a'-1,8-v[x][j].sc+1);
		}

	}
	puts("");
	//printf("%d %d\n",'a','A'); 97 /65
}
int main()
{
	int tests=1;
	//scanf("%d",&tests);
	while(tests--)
	{
		solve();
	}
	return 0;
}

POJ-2993

#include <algorithm>
#include <cstring>
#include <cstdio>
#include <iostream>
#include <utility>
#include <vector>
#include <cmath>
#define fi first
#define sc second
using namespace std;
typedef long long LL;
typedef pair<int,int>PII;
const int N=110;
char g[N][N],w[N],b[N];
int ne[6]={'K','Q','R','B','N','P'};
void draw()
{
	string s1="+---",s2="...",s3=":::";
	int tt=0;
	for(int i=0;i<=16;i++)
	{
		string s;
		//string s="+---";
		if(i&1)
		{
			tt++;
			for(int j=1;j<=8;j++)
			{
				s+="|";
				if(tt&1)
				{
					if(j&1)s+=s2;
					else s+=s3;
				}
				else
				{
					if(j&1)s+=s3;
					else s+=s2;
				}
			}
				s+="|";
		}
		else
		{
			for(int j=1;j<=8;j++)s+=s1;  s+="+";
		}
		for(int j=0;j<s.size();j++)g[i][j]=s[j];
		//printf("%s\n",g[i]);
	}
}
void solve()
{
	vector <PII>v[1000];
	draw();
	gets(w);
	//cout<<w[7];
	v[w[7]].push_back({w[8]-'a'+1,w[9]-'0'});//5 1
	//printf("%d %d\n",v[w[7]][0].fi,v[w[7]][0].sc);
	for(int i=7;i<strlen(w);i++)
	{
		if(w[i]==',')
		{
			if(w[i+1]<'a')
			{
				v[w[i+1]].push_back({w[i+2]-'a'+1,w[i+3]-'0'});
			}
			else
		        {
			         v['P'].push_back({w[i+1]-'a'+1,w[i+2]-'0'});
		         }
		}
	}
	//printf("%d....\n",v['P'].size());
	int hh=1;
	for(int i=15;i>=1;i-=2)
	{
		int tt=0;
		for(int j=2;j<=30;j+=4)
		{
			tt++;
			for(int k=0;k<6;k++)
			{
				int x=ne[k];
				for(int m=0;m<v[x].size();m++)
				{
					if(v[x][m].fi==tt&&v[x][m].sc==hh)
					{
						g[i][j]=x;
					}
				}
			}
		}
		hh++;
	}
	for(int i=0;i<200;i++)v[i].clear();
	gets(b);
	v[b[7]].push_back({b[8]-'a'+1,b[9]-'0'});//5 8
	//printf("%d %d\n",v[w[7]][0].fi,v[w[7]][0].sc);

	for(int i=7;i<strlen(b);i++)
	{
		if(b[i]==',')
		{
			if(b[i+1]<'a')
			{
				v[b[i+1]].push_back({b[i+2]-'a'+1,b[i+3]-'0'});
			}
			else
		        {
			         v['P'].push_back({b[i+1]-'a'+1,b[i+2]-'0'});
		         }
		}
	}
	 hh=1;
	for(int i=15;i>=1;i-=2)
	{
		int tt=0;
		for(int j=2;j<=30;j+=4)
		{
			tt++;
			for(int k=0;k<6;k++)
			{
				int x=ne[k];
				for(int m=0;m<v[x].size();m++)
				{
					if(v[x][m].fi==tt&&v[x][m].sc==hh)
					{
						g[i][j]=char(x+32);
					}
				}
			}
		}
		hh++;
	}
	for(int i=0;i<=16;i++)cout<<g[i]<<endl;
}
int main()
{
	int tests=1;
	scanf("%d",&tests);
	while(tests--)
	{
		solve();
	}
	return 0;
}