网络编程五子棋代码.docVIP

  • 4
  • 0
  • 约9.19千字
  • 约 20页
  • 2017-02-09 发布于重庆
  • 举报
网络编程五子棋代码

#include Winsock2.h #include stdio.h #include Windows.h #includeiostream using namespace std; //定义棋子类 class piece{ char color; int x,y; int win_probability; public : friend ostream operator(ostream os,const piece object); friend class Board; int Chess(char c){ color=c; return 0; } piece operator=(const piece c){ color=c.color; return *this; } int set_coordinate(int i,int j){ x=i; y=j; return 0; } }; //棋子类的输入操作符ostream operator(ostream os,const piece object){ osobject.color; return os; } //定义棋盘类 class Board{ piece b[10][10]; public: Board(){ for(int i=0;i!=10;i++) for(int j=0;j!=10;j++) if(i==0j==0){ piece a; a.Chess( ); b[i][j]=a; } else if(i==0j!=0){ piece a; a.Chess(j+0); b[i][j]=a; } else if(j==0i!=0){ piece a; a.Chess(i+0); b[i][j]=a; } else { piece a; a.Chess(_); b[i][j]=a; } } int modify_color(const size_t x,const size_t y,const char );//设置棋子类的颜色属性的函数 int Display_board();//输出当前棋盘状态的函数 bool Compare(const size_t x,const size_t y,const char a);//比较坐标为x,y的棋子的color与参数a bool o_win(const char);//判断o方是否获胜 bool x_win(const char);//判断x放是否获胜 bool draw_game();//判断是否和棋 }; int Board::modify_color(const size_t x,const size_t y,const char c){ b[x][y].Chess(c); return 0; } int Board::Display_board(){ for(int i=0;i!=10;i++){ for(int j=0;j!=10;j++) coutb[i][j].color; coutendl; } return 0; } bool Board::Compare(const size_t x,const size_t y,const char a){ return b[x][y].color==a; } bool Board::o_win(const char a){ int i,j; for(i=0;i10;i++) for(j=0;j6;j++) if(Compare(i,j,a)Compare(i,j+1,a)Compare(i,j+2,a)Compare(i,j+3,a)Compare(i,j+4,a)) return 1; for(j=0;j10;j++) for(i=0;i6;i++) if(Compare(i,j,a)Compare(i+1,j,a)Compare(i+2,j,a)Compare(i+3,j,a)Compare(i+4,j,a)) return 1; for(i=0;i6;i++) for(j=0;j6;j++) if(Compare(i,j,a)Compare(i+1,j+1,a)Compare(i+2,j+2,a)Compare(i+3,j+3,a)Compare(i+4,j+4,a)) return 1; for(i=0;i6;i++) for(j=9;j3;j--) if(Compare(i,j,a)Compare(i+1,j-1,a)Compare(i+2,j-2,a)Compare(i+3,j-3,a)Compare(i+4,j-4,a)) return 1; return 0; } bool

文档评论(0)

1亿VIP精品文档

相关文档