洛谷P2033 Chessboard Dance

文章描述了一个使用C++编程实现的棋盘游戏,其中包含一个8x8的矩阵表示棋盘,通过DFS进行深度优先搜索来模拟棋子移动,并处理move(前进)和turn(转向)命令。棋子的方向由一个方向变量控制,可以左转、右转或后转,始终保持在棋盘内。程序会读取用户输入的指令来执行相应的操作,并更新棋盘状态。
摘要由CSDN通过智能技术生成

本人第一道蓝题,希望各位喜欢;

最后有完整代码!;

首先,我们分析它是一个矩阵,所以定义一个二维数组:

char q[10][10];

输入:

for(int i = 0;i < 8;i++){

for(int j = 0;j < 8;j++){

cin >> q[i][j];

}

}

没什么好讲的;

然后要遍历整个矩阵,这里我用dfs来遍历;附上代码:

void dfs(int x,int y){//深搜不必

int lx = x + nx[f];//x

int ly = y + ny[f];//y

if(lx < 0 || lx > 7 || ly < 0 || ly > 7){//边界条件;

return;

}

if(q[lx][ly] != '.'){//如果当前方向前面有棋子

dfs(lx,ly);//递归

}

q[lx][ly] = q[x][y];//棋子前移

q[x][y] = '.';//变空,因为已走;

nwx = lx;//向前走的位置;

nwy = ly;//变为lx,ly

}

//其实也就是判断一下是否为空!!!;

接着就是主函数中的输入字符串然后执行;

如果是move那么向前移动,判断是否到头;

如果是turn 那么判断是left还是righ还是back是左转还是右转还是向后转;这里注意判断是否超出;

cin>>s;//先输入一个!!!关键;

int a;//move命令;

while(s != "#"){//结束

if(s == "move"){//如果是向前走的话;

cin >> a;//走多少步

for(int i = 0;i < a;i++){

dfs(nwx,nwy);//参考第7行d函数

}

}

if(s == "turn"){//转向

cin >> s;

if(s == "left"){

f--;//往左

}

if(s == "right"){

f++;//往右

}

if(s == "back"){

f += 2;//往后

}

if(f >= 4){//如果超出

f -= 4;//转回去

}

if(f < 0){//为负数;

f += 4;//重回;

}

}

cin >> s;//再次输入命令

}

最后设上方向标然后输出就好啦!;

q[nwx][nwy] = vis[f];//将你设成当前方向的状态

for(int i = 0;i < 8;i++){

for(int j = 0;j < 8;j++){

cout << q[i][j];

}

cout << endl;

}

最后附上完整代码:

#include<bits/stdc++.h>

using namespace std;

string s;

char q[10][10];//初步设定好棋盘;

char vis[5]={'<','^','>','v'};//方向表

int nx[4]={0,-1,0,1};//坐标;

int ny[4]={-1,0,1,0};

int nwx,nwy;//你的位置;

int f;//方向的变量

void dfs(int x,int y){//深搜不必

int lx = x + nx[f];//x

int ly = y + ny[f];//y

if(lx < 0 || lx > 7 || ly < 0 || ly > 7){//边界条件;

return;

}

if(q[lx][ly] != '.'){//如果当前方向前面有棋子

dfs(lx,ly);//递归

}

q[lx][ly] = q[x][y];//棋子前移

q[x][y] = '.';//变空,因为已走;

nwx = lx;//向前走的位置;

nwy = ly;//变为lx,ly

}

int main()

{

for(int i = 0;i < 8;i++){

for(int j = 0;j < 8;j++){

cin >> q[i][j];

if(q[i][j] == '<'){//如果方向为左

f = 0;nwx = i;nwy = j;//设置位置

}

if(q[i][j] == '^'){

f = 1;nwx = i;nwy = j;

}

if(q[i][j] == '>'){

f = 2;nwx = i;nwy = j;

}

if(q[i][j] == 'v'){

f = 3;nwx = i;nwy = j;

}

}

}

cin >> s;

int a;//move命令;

while(s != "#"){//结束

if(s == "move"){//如果是向前走的话;

cin >> a;//走多少步

for(int i = 0;i < a;i++){

dfs(nwx,nwy);//参考第7行d函数

}

}

if(s == "turn"){//转向

cin >> s;

if(s == "left"){

f--;//往左

}

if(s == "right"){

f++;//往右

}

if(s == "back"){

f += 2;//往后

}

if(f >= 4){//如果超出

f -= 4;//转回去

}

if(f < 0){//为负数;

f += 4;//重回;

}

}

cin >> s;//再次输入命令

}

q[nwx][nwy] = vis[f];//将你设成当前方向的状态

for(int i = 0;i < 8;i++){

for(int j = 0;j < 8;j++){

cout << q[i][j];

}

cout << endl;

}

return 0;

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值