IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C语言初学者实现的五子棋 -> 正文阅读

[C++知识库]C语言初学者实现的五子棋

int main()
{
    int i,j;//棋盘坐标
    int qipan[20][20];//规定棋盘大小           
       // 绘制棋盘
       int qizi=-1;
        int  qizicount=1;
       int tj,ti;
    for(i=0;i<20;i++)
      {
          for(j=0;j<20;j++)
          {
              qipan[i][j]=2;
          }
      }       //历遍棋盘,赋值为2;
  while(1)
  {
      printf("请输入棋子位置如2,2\n");
      scanf("%d,%d",&i,&j);
      if(i<1||i>20||j<1||j>20)
      {
          printf("棋子超出棋盘位置,请重新输入");
          continue; //跳过下列循环语句 从头开始循环
      }

       if((qipan[i-1][j-1]!=2))
       {
           printf("此位置已有棋子请重新输入");
           fflush(stdin);
           continue;

       }
        qizi=(qizi+1)%2;
       qipan[i-1][j-1]=qizi; //输入黑棋位置
      for(i=0;i<20;i++)
      {
          if(i==0)  //第一行
          {
              for(j=0;j<20;j++)
              {
                  if(j==0) //第一列
                  {
                      if(qipan[i][j]==2)
                        printf("┌ ");
                        else if(qipan[i][j]==0)
                        printf("●");
                        else if(qipan[i][j]==1)
                            printf("○");
                  }
                  else if(j>0&&j<19)
                  {
                      if(qipan[i][j]==2)
                        printf("┬ ");
                        else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }
                  else if(j==19)
                  {
                      if(qipan[i][j]==2)
                        printf("┐");
                      else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }
              }
              printf("\n");
          }
          else if(i>0&&i<19)   // 1到19行
          {
              for(j=0;j<20;j++)
              {
                  if(j==0)
                  {
                      if(qipan[i][j]==2)
                        printf("├ ");
                        else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }
                  else if(j>0&&j<19)
                  {
                      if(qipan[i][j]==2)
                        printf("┼ ");
                        else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }
                  else if(j==19)
                  {
                      if(qipan[i][j]==2)
                        printf("┤");
                      else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }

             }
       printf("\n");
      }

       else if(i==19)
       {
            for(j=0;j<20;j++)
              {
                  if(j==0)
                  {
                      if(qipan[i][j]==2)
                        printf("└ ");
                        else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }
                  else if(j>0&&j<19)
                  {
                      if(qipan[i][j]==2)
                        printf("┴ ");
                        else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }
                  else if(j==19)
                  {
                      if(qipan[i][j]==2)
                        printf("┘");
                      else if(qipan[i][j]==0)
                        printf("●");
                          else if(qipan[i][j]==1)
                            printf("○");
                  }

             }
       printf("\n");
       }

  }        //以上为绘制棋盘棋子

for(i=0;i<20;i++)  //横方向判断
{
    for(j=0;j<20;j++)
    {
        if(qipan[i][j]!=2)
        {
            ti=i;tj=j;
            for(tj=j+1;qipan[ti][tj]!=2&&tj<19;tj++){
                if(qipan[ti][tj]==qipan[ti][tj-1])
                qizicount++;
                else break;
                 if(qizicount==5)
                    break;}


        }
        if(qizicount==5)
            {
                if(qipan[ti][tj]==0)

                       printf("白棋赢了");



                    else if(qipan[ti][tj]==1)
                    printf("黑棋赢了");
            }
        else qizicount=1;
        if (qizicount==5)
            break;
    }
    if (qizicount==5)
            break;
}
for(j=0;j<20;j++)  //竖方向判断
{
    for(i=0;i<20;i++)
    {
        if(qipan[i][j]!=2)
        {
            tj=j;
            for(ti=i;qipan[ti+1][tj]==qipan[ti][tj]&&tj<19;ti++){

                qizicount++;
                 if(qizicount==5)
                    break;}

            }
            if(qizicount==5)
            {
                    if(qipan[ti][tj]==0)
                        printf("白棋赢了");
                    else if(qipan[ti][tj]==1)
                    printf("黑棋赢了");

            }
            else  qizicount=1;
            if(qizicount==5)
            break;
        }
        if(qizicount==5)
            break;
    }
    for(i=0;i<20;i++) //从左上到右下
    {
        for(j=0;j<20;j++)
        {
            if(qipan[i][j]!=2)

            for(tj=j,ti=i;qipan[ti][tj]!=2&&tj<19;tj--,ti--){
                if(qipan[ti][tj]==qipan[ti-1][tj-1])
                qizicount++;
                else break;
                 if(qizicount==5)
                    break;}

        }
        if(qizicount==5)
            {
                    if(qipan[ti][tj]==0)
                        printf("白棋赢了");
                    else if(qipan[ti][tj]==1)
                    printf("黑棋赢了");

            }
            else  qizicount=1;
            if(qizicount==5)
            break;
    }
for(i=0;i<20;i++) //右上到左下
    {
        for(j=0;j<20;j++)
        {
            if(qipan[i][j]!=2)

            for(tj=j,ti=i;qipan[ti][tj]!=2&&tj<19;tj++,ti--){
                if(qipan[ti][tj]==qipan[ti-1][tj+1])
                qizicount++;
                else break;
                 if(qizicount==5)
                    break;}

        }
        if(qizicount==5)
            {
                    if(qipan[ti][tj]==0)
                        printf("白棋赢了");
                    else if(qipan[ti][tj]==1)
                    printf("黑棋赢了");

            }
            else  qizicount=1;
            if(qizicount==5)
            break;
    }
if(qizicount==5)
{
    break;
}

}



return 0;
}

   /*************************************************
    *
    *绘制表格需要的字符:┌ ┬ ┐├ ┼ ┤└ ┴ ┘│─●○
    *数组的值1表示黑棋,0表示白棋,2表示该位置没有棋
    *
    */

萌新上路代码不完善请多指教;

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-24 18:17:43  更:2021-12-24 18:19:33 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 0:16:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码