五子棋(可判断输赢)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 | #include <iostream> #include <iomanip> using namespace std; int row=16; int col=16; int all[17][17]; bool black= true ; bool whilt; int x,y; int a=1; int t=0; int e=0; bool win(){ int l=all[x][y]; if (all[x][y-1]==l&&all[x][y-2]==l&&all[x][y-3]==l&&all[x][y-4]==l){ e=1; } else if (all[x][y-1]==l&&all[x][y-2]==l&&all[x][y-3]==l&&all[x][y+1]==l){ e=1; } else if (all[x][y-1]==l&&all[x][y-2]==l&&all[x][y+1]==l&&all[x][y+2]==l){ e=1; } else if (all[x][y-1]==l&&all[x][y+1]==l&&all[x][y+2]==l&&all[x][y+3]==l){ e=1; } else if (all[x][y+1]==l&&all[x][y+2]==l&&all[x][y+3]==l&&all[x][y+4]==l){ e=1; } else if (all[x-1][y]==l&&all[x-2][y]==l&&all[x-3][y]==l&&all[x-4][y]==l){ e=1; } else if (all[x-1][y]==l&&all[x-2][y]==l&&all[x-3][y]==l&&all[x+1][y]==l){ e=1; } else if (all[x-1][y]==l&&all[x-2][y]==l&&all[x+2][y]==l&&all[x+1][y]==l){ e=1; } else if (all[x-1][y]==l&&all[x+3][y]==l&&all[x+2][y]==l&&all[x+1][y]==l){ e=1; } else if (all[x+4][y]==l&&all[x+3][y]==l&&all[x+2][y]==l&&all[x+1][y]==l){ e=1; } else if (all[x+1][y-1]==l&&all[x+2][y-2]==l&&all[x+3][y-3]==l&&all[x+4][y-4]==l){ e=1; } else if (all[x+1][y-1]==l&&all[x+2][y-2]==l&&all[x+3][y-3]==l&&all[x-1][y+1]==l){ e=1; } else if (all[x+1][y-1]==l&&all[x-3][y+3]==l&&all[x-2][y+2]==l&&all[x-1][y+1]==l){ e=1; } else if (all[x+1][y-1]==l&&all[x-3][y+3]==l&&all[x-2][y+2]==l&&all[x-1][y+1]==l){ e=1; } else if (all[x-4][y+4]==l&&all[x-3][y+3]==l&&all[x-2][y+2]==l&&all[x-1][y+1]==l){ e=1; } else if (all[x+1][y+1]==l&&all[x+2][y+2]==l&&all[x+3][y+3]==l&&all[x+4][y+4]==l){ e=1; } else if (all[x+1][y+1]==l&&all[x+2][y+2]==l&&all[x+3][y+3]==l&&all[x-1][y-1]==l){ e=1; } else if (all[x+1][y+1]==l&&all[x+2][y+2]==l&&all[x-2][y-2]==l&&all[x-1][y-1]==l){ e=1; } else if (all[x+1][y+1]==l&&all[x-3][y-3]==l&&all[x-2][y-2]==l&&all[x-1][y-1]==l){ e=1; } else if (all[x-4][y-4]==l&&all[x-3][y-3]==l&&all[x-2][y-2]==l&&all[x-1][y-1]==l){ e=1; } } void f5(){ cout<< " " ; for ( int j=1;j<=col;j++){ cout<<setw(3)<<j; } cout<<endl; for ( int i=1;i<=row;i++){ cout<<setw(2)<<i; for ( int j=1;j<=col;j++){ if (all[i][j]==0){ cout<<setw(3)<< "." ; } else if (all[i][j]==1){ cout<<setw(3)<< "黑" ; } else { cout<<setw(3)<< "白" ; } } cout<<endl; } } int main( int argc, char ** argv) { for ( int i=0;i<17;i++){ for ( int j=0;j<17;j++){ all[i][j]=0; } } while ( true ){ system( "cls" ); f5(); if (black){ cout<< "黑棋请落子:" ; cin>>x>>y; if (x>16||y>16||all[x][y]!=0){ continue ; } all[x][y]=1; black= false ; win(); if (e==1){ system( "cls" ); f5(); cout<< "黑方win" ; return 0; } } else { cout<< "白棋请落子:" ; cin>>x>>y; if (x>16||y>16||all[x][y]!=0){ continue ; } all[x][y]=2; win(); if (e==1){ system( "cls" ); f5(); cout<< "白方win" ; return 0; } black= true ; } } return 0; } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报