急需用c语言写中国象棋的代码,只要红色方布局和走棋

急需用c语言写中国象棋的代码,只要红色方布局和走棋,第1张

#include #include #include #include #include

int x,y,i,j,k,p,q, num = 1, round //象棋游戏的全局变量

int place_x1 = 0,place_y1 = 0,place_x2 = 0,place_y2 = 0

int check_x,check_y,check_turn //基本参数

char ch, turn = 'O',turn1 = 'N',temp,temp1

char check_1[9][3] ={"车","马","象","士","将","炮","兵","+-"} //取棋子时只判断前8合法

char check_2[9][3] ={"车","马"肢斗睁,"相","仕","帅","炮","卒","+-"} //下棋时多一空位合法销指

char check[3]

void check_main1(char* temp,char* temp1,char* turn,char* turn1,int *num,int *if_return,char map[100][100])

{ //(象棋函数历岁 判断 将方 下棋是否合法

check[0] = *temp check[1] = *temp1 check[2] = '\0' char a,b

for ( i = 0i <8i++)

{ if ( strcmp(check_2[i],check) == 0)

{ *temp = *turn *temp1 = *turn1 *turn = 'O' *turn1 = 'N'

if( i <7){ printf(" 帅方的%s被吃\n",check_2[i]) Sleep(500)} *num = *num + 1

for( k = 4k <= 8k = k + 2) //判断 帅 是否死亡

{ for(j = 15j <= 23j= j+ 4)

{ if (map[k][j] == check_2[4][0] &&map[k][j+1] == check_2[4][1])

{ place_x2 = k place_y2 = j break} }

if( j <= 23) break

}

if( k == 10)

{printf(" 帅 被将死 将方获得胜利\n")printf("按任意键返回菜单")

getch( ) *if_return = 1return

}

for( k = 18k <= 22k = k + 2) //判断 将 是否死亡

{for(j = 15j <= 23j= j+ 4)

{if(map[k][j] == check_1[4][0] &&map[k][j+1] == check_1[4][1])

{place_x1 = k place_y1 = j break} }

if( j <= 23) break

}

if ( k == 24)

{printf(" 将 被将死 帅方获得胜利\n")printf("按任意键返回菜单")

getch( ) *if_return = 1 return

}

if ( place_y1 == place_y2)

{for( k = place_x2 + 2k <= place_x1 - 2k = k +2) {if(map[k][place_y1] != '+') break}

if( k == place_x1)

{if(round == 1) printf(" 将方对将 帅方胜利")

else if( round == 2) printf(" 帅方对将 将方胜利")

printf("按任意键返回菜单") getch( ) *if_return = 1 return

}

}

break

}

} // for ( i = 0i <8i++)循环结束

if( i == 8) {printf("不合法的走法\n")Sleep(500)}

}

void check_main2(char* temp,char* temp1,char* turn,char* turn1,int *num,int *if_return,char map[100][100])

{ //象棋函数 判断 帅方 下棋是否合法

check[0] = *temp check[1] = *temp1 check[2] = '\0' char a,b

for ( i = 0i <8i++)

{if ( strcmp(check_1[i],check) == 0)

{ *temp = *turn *temp1 = *turn1 *turn = 'O' *turn1 = 'N'

if( i <7) {printf(" 将方的%s被吃",check_1[i]) Sleep(500)}*num = *num + 1

for( k = 4k <= 8k = k + 2) //判断 帅 是否死亡

{for(j = 15j <= 23j= j+ 4)

{if(map[k][j] == check_2[4][0] &&map[k][j+1] == check_2[4][1])

{place_x2 = k place_y2 = j break} }

if( j <= 23) break

}

if( k == 10)

{printf(" 帅 被将死 将方获得胜利\n")printf("按任意键返回菜单") getch( )

*if_return = 1 return

}

for( k = 18k <= 22k = k + 2) //判断 将 是否死亡

{for(j = 15j <= 23j= j+ 4)

{if(map[k][j] == check_1[4][0] &&map[k][j+1] == check_1[4][1])

{place_x1 = k place_y1 = j break} }

if( j <= 23) break

}

if( k == 24)

{printf(" 将 被将死 帅方获得胜利\n")printf("按任意键返回菜单") getch( )

*if_return = 1 return}

if( place_y1 == place_y2)

{for( k=place_x2 + 2k <= place_x1 - 2k=k +2) {if(map[k][place_y1] != '+') break}

if( k == place_x1)

{if(round==1)printf(" 将方对将 帅方胜利")else if(round==2)printf(" 帅方对将 将方胜利")

printf("按任意键返回菜单") getch( ) *if_return = 1 return }

}

break

}

} // for ( i = 0i <8i++)循环结束

if( i == 8) {printf("不合法的走法\n")Sleep(500)}

}

void xiangqi( ) //象棋主程序

{ char map[100][100]= { "[[===================================]]",

"[| ①将 【象棋】②帅 |]",

"[[===================================]]",

"[[-----------------------------------]]",

"[[ 车—-马—-相—-仕—-帅—-仕—-相—-马—-车]]",

"[[ | | | | \\ | / | | | | ]]",

"[[ +-—-+-—-+-—-+-—-+-—-+-—-+-—-+-—-+-]]",

"[[ | | | | / | \\ | | | | ]]",

"[[ +-—-炮—-+-—-+-—-+-—-+-—-+-—-炮—-+-]]",

"[[ | | | | | | | | | ]]",

"[[ 卒—-+-—-卒—-+-—-卒—-+-—-卒—-+-—-卒]]",

"[[ | | | | | | | | | ]]",

"[[ +-—-+-—-+-—-+-—-+-—-+-—-+-—-+-—-+-]]",

"[[===================================]]",

"[[ +-—-+-—-+-—-+-—-+-—-+-—-+-—-+-—-+-]]",

"[[ | | | | | | | | | ]]",

"[[ 兵—-+-—-兵—-+-—-兵—-+-—-兵—-+-—-兵]]",

"[[ | | | | | | | | | ]]",

"[[ +-—-炮—-+-—-+-—-+-—-+-—-+-—-炮—-+-]]",

"[[ | | | | \\ | / | | | | ]]",

"[[ +-—-+-—-+-—-+-—-+-—-+-—-+-—-+-—-+-]]",

"[[ | | | | / | \\ | | | | ]]",

"[[ 车—-马—-象—-士—-将—-士—-象—-马—-车]]",

"[[-----------------------------------]]",

"[[===================================]]"}

int if_return = 0

system("mode con cols=45 lines=32") //迷你界面

system("color 70")

printf("[[==================================]]\n")

printf("[[ -------------------------------- ]]\n")

printf("[[ | | ]]\n")

printf("[[ | 【<>】 | ]]\n")

printf("[[ | | ]]\n")

printf("[[ |------------------------------| ]]\n")

printf("[[ | 控制wasd双方轮流控制指针下棋| ]]\n")

printf("[[ |------------------------------| ]]\n")

printf("[[ | 键盘输入大小写 ' M '| ]]\n")

printf("[[ | 都视为确认下棋 | ]]\n")

printf("[[ |------------------------------| ]]\n")

printf("[[ | 为了方便区分棋子 | ]]\n")

printf("[[ | 后手方全设为繁体复杂字体| ]]\n")

printf("[[ |------------------------------| ]]\n")

printf("[[ |------------------------------| ]]\n")

printf("[[ | 我已阅读规则,按任意键继续 | ]]\n")

printf("[[ |------------------------------| ]]\n")

printf("[[==================================]]\n")

getch( ) system("mode con cols=45 lines=32") //迷你界面

system("color 70")

for ( i = 0i <27i++){ puts(map[i]) Sleep(100)}

x = 6, y = 19 temp = map[x][y] temp1 = map[x][y+1]

while(num)

{ if (num % 2 == 1 &&num / 2 % 2 == 0){ printf(" 现在是'将'的回合\n")round = 1}

else if( num %2 == 1){ printf(" 现在轮到'帅'的回合了\n")round = 2}

ch = getch( )

if ( ch == 's') //下移

{ if ( map[x+1][y]!= '-')

{map[x][y] =temp map[x][y+1] = temp1 x = x + 2

temp = map[x][y] temp1 = map[x][y+1] map[x][y] = turn map[x][y+1] = turn1}

}

else if ( ch == 'a') //左移

{ if (map[x][y-1]!=' ')

{map[x][y] =temp map[x][y+1] = temp1y = y - 4

temp = map[x][y] temp1 = map[x][y+1] map[x][y] = turn map[x][y+1] = turn1}

}

else if ( ch == 'w') //上移

{ if ( map[x-1][y]!= '-')

{map[x][y] =temp map[x][y+1] = temp1x = x - 2 temp = map[x][y]

temp1 = map[x][y+1]map[x][y] = turn map[x][y+1] = turn1 }

}

else if ( ch == 'd') //右移

{ if (map[x][y+2]!=']')

{map[x][y] =temp map[x][y+1] = temp1y = y + 4 temp = map[x][y]

temp1 = map[x][y+1]map[x][y] = turn map[x][y+1] = turn1 }

}

else if( ch == 'm' || ch =='M') //M确认要移动的棋子,或确认要移到的目的地

{ if (num % 2 == 1 &&temp != '+' &&temp1 != '-') //取棋

{check[0] = temp check[1] = temp1 check[2] = '\0'

if ( round == 1)

{ for ( i = 0i <7i++)//将方

{ if ( strcmp(check_1[i],check) == 0)

{turn = temp turn1 = temp1 temp = '+' temp1 = '-'

check_x = x check_y = y check_turn = 10 + i num++ break}

}

if( i == 7){ printf("这不是你的棋子\n")Sleep(500)}

}

else if( round == 2)

{for ( i = 0i <7i++) //帅方

{ if( strcmp(check_2[i],check) == 0)

{turn = temp turn1 = temp1 temp = '+' temp1 = '-'

check_x = x check_y = y check_turn = 20 + i num++ break }

}

if( i == 7){ printf("这不是你的棋子\n")Sleep(500)}

}

}

else if( num % 2 == 0) //放棋

{ char check_1[8][3] ={"车","马","象","士","将","炮","卒","+-"}

char check_2[8][3] ={"俥","马","相","仕","帅","軳","兵","+-"}

//中界 楚河上下坐标 12 15 往下2 往右4

if( check_turn <20) //将方

{if( check_turn == 10) //车的走法规范

{ if((x == check_x &&y == check_y))

{temp = turn temp1 = turn1 turn = 'O' turn1 = 'N' num--

printf("三思而后行\n")printf("还是你的回合")Sleep(500) }

else if( y == check_y )

{ if( x >check_x)

{ for(j = check_x + 2j <xj = j + 2)

{ if(map[j][y] == '+')else{printf("不合法的下法\n")Sleep(500)break} }

if( j >= x) check_main1(&temp,&temp1,&turn,&turn1,&num,&if_return,map)

}

if( x check_x){ for(j = check_x - 2j >xj = j - 2)

{ if(map[j][y] == '+')else{printf("不合法的下法\n")Sleep(500)break}

}

if( j <= x)check_main1(&temp,&temp1,&turn,&turn1,&num,&if_return,map)

}

}

else if( x == check_x )

{if( y >check_y)

{for(j = check_y + 4j <yj = j + 4)

{if(map[x][j] == '+')else {printf("不合法的下法\n")Sleep(500) break}

}

if( j >= y) check_main1(&temp,&temp1,&turn,&turn1,&num,&if_return,map)

}

if( y <check_y)

{for(j = check_y - 4j >yj = j - 4)

{ if(map[x][j] == '+')else { printf("不合法的下法\n")Sleep(500) break}

}

if( j <= y) check_main1(&temp,&temp1,&turn,&turn1,&num,&if_return,map)

}

}

else { printf("不合法的下法\n")Sleep(500)}

}

if( check_turn == 11) //马的走法规范

{if((x == check_x &&y == check_y))

{ temp = turn temp1 = turn1 turn = 'O' turn1 = 'N' num--

printf("三思而后行\n")printf("还是你的回合")Sleep(500) }

else if( (abs( x - check_x) == 2&&abs( y - check_y) == 8)&&map[check_x][(y+check_y)/2] =='+')

{check_main1(&temp,&temp1,&turn,&turn1,&num,&if_return,map)}

else if( (abs( x - check_x) == 4&&abs( y - check_y) == 4)&&map[(x + check_x)/2][check_y] == '+' )

{check_main1(&temp,&temp1,&turn,&turn1,&num,&if_return,map)}

else { printf("不合法的下法\n")Sleep(500)}

} //其余代码在后续

#include<stdio.h>

/*

问题描答昌述:在n*m的棋盘上,马只能走日字。马从(x,y)出发,把棋盘的每一个点都走一遍,且只走一次,

找出所有路径。

*/

void find(int x,int y,int dep)

int check(int x,int y)

void output()

int n=5,m=4

int fx[8]={1,2,2,1,-1,-2,-2,-1}

int fy[8]={2,1,-1,-2,-2,-1,1,2}

int a[5][4]

int dep,x,y,count

int main()

{

int i,j

dep=1////记录递归深度,即走过的点的个数,当dep=n*m,找到一组解

count=0

printf("Please input the original point:\n")

scanf("%d%d",&x,&y)

if(x<0 || x>4 || y<0 || y>3)

{

printf("wrong data!\n")

return 1

}

for(i=0i<ni++)

{

for(j=0j<mj++)

{

a[i][j]=0

}

}

a[x][y]=1

find(x,y,2)

if(count==0)

{

printf("NO solution!\n")

}

else

{

printf("Total count=%d\n",count)

}

return 0

}

void find(int x,int y,int dep)

{

int i

int xx,yy

for(i=0i<8i++)//加上方向增量,形成新的坐标

{

xx=x+fx[i]

yy=y+fy[i]

if(check(xx,yy)==1)//判断坐标是否出界,或者已经走过

{

a[xx][yy]=dep//走向新的坐标

if(dep==n*m)

{

output()

}

else

{

find(xx,yy,dep+1)//从新的坐标出发,递归下一层

}

a[xx][yy]=0//回溯,恢复未走标志

}

}

}

int check(int x,int y)

{

int flag = 1

if(x<0 || x>4 || y<0 || y>3)

{

flag = 0

}

if(a[x][y]!=0)

{

flag=0

}

return flag

}

void output()

{

count++

printf("\ncount=%d\n",count)

int i,j

for(i=0i<ni++)

{

for(j=0j<清樱扒mj++)

{

printf("%4d",a[i][j])

}

printf("颂枝\n")

}

}

//原始文件请参考:CSDN马的遍历问题


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12391591.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存