Emag eht htiw Em Pleh

棋盘布局解析
本文介绍了一个从特定格式的棋子布局描述中解析并还原国际象棋棋盘布局的方法。通过输入白方和黑方棋子的位置信息,程序能够正确地绘制出对应的棋盘布局。此方法适用于需要从文字描述中还原棋盘状态的应用场景。

Description

This problem is a reverse case of the  problem 2996. You are given the output of the problem H and your task is to find the corresponding input.

Input

according to output of  problem 2996.

Output

according to input of  problem 2996.

Sample Input

White: Ke1,Qd1,Ra1,Rh1,Bc1,Bf1,Nb1,a2,c2,d2,f2,g2,h2,a3,e4
Black: Ke8,Qd8,Ra8,Rh8,Bc8,Ng8,Nc6,a7,b7,c7,d7,e7,f7,h7,h6

Sample Output

+---+---+---+---+---+---+---+---+
|.r.|:::|.b.|:q:|.k.|:::|.n.|:r:|
+---+---+---+---+---+---+---+---+
|:p:|.p.|:p:|.p.|:p:|.p.|:::|.p.|
+---+---+---+---+---+---+---+---+
|...|:::|.n.|:::|...|:::|...|:p:|
+---+---+---+---+---+---+---+---+
|:::|...|:::|...|:::|...|:::|...|
+---+---+---+---+---+---+---+---+
|...|:::|...|:::|.P.|:::|...|:::|
+---+---+---+---+---+---+---+---+
|:P:|...|:::|...|:::|...|:::|...|
+---+---+---+---+---+---+---+---+
|.P.|:::|.P.|:P:|...|:P:|.P.|:P:|
+---+---+---+---+---+---+---+---+
|:R:|.N.|:B:|.Q.|:K:|.B.|:::|.R.|
+---+---+---+---+---+---+---+---+

Source



/*
棋盘的还原;
*/
#include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
//const int Maxn=1100000;
char str[]="+---+---+---+---+---+---+---+---+";//奇数行输出;
char s1[]="|:::|...|:::|...|:::|...|:::|...|";//4的倍数行的选择;
char s2[]="|...|:::|...|:::|...|:::|...|:::|";//2的倍数行的选择;
char Map[55][55];//标记每行每列的字符;
void Trans(char s[])//位置坐标转化为字母;
{
    bool flag=false;
    if(s[0]=='B')//黑棋;
        flag=true;
    for(int i=7;s[i];)
    {
        if(s[i]>='A'&&s[i]<='Z')
        {
            int u=s[i+1]-'a'+1;//纵坐标的标记;
            int  v=s[i+2]-'0';//横坐标的标记;
            if(flag)
            {
                Map[v][u]=s[i]+32;//黑棋代表的是小写字母;
            }
            else
            {
                Map[v][u]=s[i];//白棋即大写字母;
            }
            i+=4;
        }
        else if(s[i]>='a'&&s[i]<='z')//p位置的确定;
        {
            int u=s[i]-'a'+1;//纵坐标
            int v=s[i+1]-'0';//横坐标;
            if(flag)
                Map[v][u]='p';//黑棋;
            else
                Map[v][u]='P';//白棋;
                i+=3;
        }
    }
}
int main()
{
    char white[110];
    char black[110];
    memset(white,'\0',sizeof(white));
    memset(black,'\0',sizeof(black));
    //getchar();
    gets(white);
    gets(black);
    memset(Map,0,sizeof(Map));
    Trans(white);
    Trans(black);
    int u=8;//共八行;;
    for(int i=17;i>=1;i--)
    {
        if(i%2)
        {
            printf("%s\n",str);
        }
        else
        {
            int ans=2;
            int v=1;
            if((i/2)%2)//
            {
                for(int j=0;j<33;j++)
                {
                    if(j!=ans)//不是棋子;
                    {
                        printf("%c",s1[j]);
                    }
                    else
                    {
                        if(Map[u][v])//有棋子;
                        {
                            printf("%c",Map[u][v]);
                        }
                        else
                            printf("%c",s1[j]);
                          v++;//纵坐标加一;
                        ans+=4;
                    }
                }
            }
            else
            {
                for(int j=0;j<33;j++)
                {
                    if(j!=ans)
                    {
                        printf("%c",s2[j]);
                    }
                    else
                   {
                       if(Map[u][v])
                       {
                           printf("%c",Map[u][v]);
                       }
                       else
                       {
                           printf("%c",s2[j]);
                       }
                       v++;
                       ans+=4;
                   }
                }
            }
            printf("\n");
            u--;
        }
    }
    return 0;
}




【数据驱动】【航空航天结构的高效损伤检测技术】一种数据驱动的结构健康监测(SHM)方法,用于进行原位评估结构健康状态,即损伤位置和程度,在其中利用了选定位置的引导式兰姆波响应(Matlab代码实现)内容概要:本文介绍了一种基于数据驱动的结构健康监测(SHM)方法,利用选定位置的引导式兰姆波响应对航空航天等领域的结构进行原位损伤检测,实现对损伤位置与程度的精确评估,相关方法通过Matlab代码实现,具有较强的工程应用价值。文中还提到了该技术在无人机、水下机器人、太阳能系统、四轴飞行器等多个工程领域的交叉应用,展示了其在复杂系统状态监测与故障诊断中的广泛适用性。此外,文档列举了大量基于Matlab/Simulink的科研仿真资源,涵盖信号处理、路径规划、机器学习、电力系统优化等多个方向,构成一个综合性科研技术支持体系。; 适合人群:具备一定Matlab编程基础,从事航空航天、结构工程、智能制造、自动化等相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①用于航空航天结构、无人机机体等关键部件的实时健康监测与早期损伤识别;②结合兰姆波信号分析与数据驱动模型,提升复杂工程系统的故障诊断精度与可靠性;③为科研项目提供Matlab仿真支持,加速算法验证与系统开发。; 阅读建议:建议读者结合文档提供的Matlab代码实例,深入理解兰姆波信号处理与损伤识别算法的实现流程,同时可参考文中列出的多种技术案例进行横向拓展学习,强化综合科研能力。
【无人机论文复现】空地多无人平台协同路径规划技术研究(Matlab代码实现)内容概要:本文围绕“空地多无人平台协同路径规划技术”的研究展开,重点在于通过Matlab代码实现对该技术的论文复现。文中详细探讨了多无人平台(如无人机与地面车辆)在复杂环境下的协同路径规划问题,涉及三维空间路径规划、动态避障、任务分配与协同控制等关键技术,结合智能优化算法(如改进粒子群算法、遗传算法、RRT等)进行路径求解与优化,旨在提升多平台系统的协作效率与任务执行能力。同时,文档列举了大量相关研究主题,涵盖无人机控制、路径规划、多智能体协同、信号处理、电力系统等多个交叉领域,展示了该方向的技术广度与深度。; 适合人群:具备一定Matlab编程基础和路径规划背景的研究生、科研人员及从事无人机、智能交通、自动化等相关领域的工程技术人员。; 使用场景及目标:①用于学术论文复现,帮助理解空地协同路径规划的核心算法与实现细节;②支撑科研项目开发,提供多平台协同控制与路径优化的技术参考;③作为教学案例,辅助讲授智能优化算法在无人系统中的实际应用。; 阅读建议:建议结合提供的Matlab代码进行实践操作,重点关注算法实现流程与参数设置,同时可参照文中列出的其他相关研究方向拓展技术视野,建议按目录顺序系统学习,并充分利用网盘资源进行仿真验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值