鱼C论坛

 找回密码
 立即注册
查看: 1067|回复: 1

[已解决]井字棋实现简单的人工智能

[复制链接]
发表于 2023-11-9 15:22:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Eat.随 于 2023-11-9 15:24 编辑

下井字棋时,请问如何让电脑实现一些智能,现在的代码,电脑实现了随机下棋。(请务必指明哪里修改了)
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdbool.h>
  4. #include <stdlib.h>
  5. #include <time.h>

  6. void printArray(char arr[3][3])
  7. {
  8.     int i,j;
  9.     for (i=0; i<3; i++)
  10.     {
  11.         for (j=0; j<3; j++)
  12.         {
  13.             printf("%c ", arr[i][j]);
  14.         }
  15.         printf("\n");
  16.     }
  17. }

  18. bool humanwin(char arr[3][3])
  19. {
  20.     for (int i = 0; i < 3; i++)
  21.     {
  22.         if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
  23.         {
  24.             return true;
  25.         }
  26.     }
  27.     for (int j = 0; j < 3; j++)
  28.     {
  29.         if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
  30.         {
  31.             return true;
  32.         }
  33.         
  34.     }
  35.     if (arr[0][0] == 'X' && arr[1][1] == 'X' && arr[2][2] == 'X')
  36.     {
  37.         return true;
  38.     }
  39.     if (arr[0][2] == 'X' && arr[1][1] == 'X' && arr[2][0] == 'X')
  40.     {
  41.         return true;
  42.     }
  43.     return false;
  44. }

  45. bool computerwin(char arr[3][3])
  46. {
  47.     for (int i = 0; i < 3; i++)
  48.     {
  49.         if (arr[ i][0] == 'O' && arr[ i][1] == 'O' && arr[ i][2] == 'O')
  50.         {
  51.             return true;
  52.         }
  53.     }
  54.     for (int j = 0; j < 3; j++)
  55.     {
  56.         if (arr[0][j] == 'O' && arr[1][j] == 'O' && arr[2][j] == 'O')
  57.         {
  58.             return true;
  59.         }
  60.         
  61.     }
  62.     if (arr[0][0] == 'O' && arr[1][1] == 'O' && arr[2][2] == 'O')
  63.     {
  64.         return true;
  65.     }
  66.     if (arr[0][2] == 'O' && arr[1][1] == 'O' && arr[2][0] == 'O')
  67.     {
  68.         return true;
  69.     }
  70.     return false;
  71. }

  72. bool nowin(char arr[3][3])
  73. {
  74.     if (arr[0][0] != '.' && arr[0][1] != '.' && arr[0][2] != '.' && arr[1][0] != '.' && arr[1][1] != '.' && arr[1][2] != '.' && arr[2][0] != '.' && arr[2][1] != '.' && arr[2][2] != '.')
  75.     {
  76.         return true;
  77.     }
  78.     else
  79.     {
  80.         return false;
  81.     }
  82. }
  83.    

  84. void calculateRowAndCol(int x, int* row, int* col)
  85. {
  86.     *row = 2 - ((x-1) / 3);
  87.     *col = (x-1) % 3;
  88. }


  89. int main()
  90. {
  91.     char board_now[3][3] = {{'.','.','.'},{'.','.','.'},{'.','.','.'}};
  92.     int i,x,y,row,col;
  93.     for (i=0;i<9;i++)
  94.     {
  95.         for (i=0;i<5;i++)
  96.         {
  97.             printArray(board_now);
  98.             printf("human input:");
  99.             scanf("%i",&x);
  100.             calculateRowAndCol(x, &row, &col);
  101.             if (board_now[row][col] == '.')
  102.             {
  103.                 board_now[row][col] = 'X';
  104.                 printf("\033[2J\033[H");
  105.                 break;
  106.             }
  107.             else
  108.             {
  109.                 printf("\033[2J\033[H");
  110.                 printf("you have done this.please input again.\n");
  111.                 i = i-1;
  112.             }   
  113.         }
  114.         if (humanwin(board_now))
  115.         {
  116.             printArray(board_now);
  117.             printf("human win.\n");
  118.             break;
  119.         }
  120.         for (i=0;i<4;i++)
  121.         {
  122.             srand(time(NULL));
  123.             y = rand()%(9+1);
  124.             calculateRowAndCol(y, &row, &col);
  125.             if (board_now[row][col] == '.')
  126.             {
  127.                 board_now[row][col] = 'O';
  128.                 printf("\033[2J\033[H");
  129.                 break;
  130.             }
  131.             else
  132.             {
  133.                 i = i-1;
  134.                 if (nowin(board_now))
  135.                 {
  136.                     printf("nobady win.");
  137.                     break;
  138.                 }
  139.             }
  140.         }
  141.         if (computerwin(board_now))
  142.         {
  143.             printArray(board_now);
  144.             printf("computer win.\n");
  145.             break;
  146.         }  
  147.     }
  148.     return 0;     
  149. }
复制代码
最佳答案
2023-11-9 15:25:16
要让电脑实现一些智能,可以通过以下几个步骤来修改代码:

1. 添加一个函数,用于评估当前棋局的得分。可以根据棋局的优势和劣势来给棋局打分。例如,如果电脑有可能获胜,那么分数就会高一些;如果对手有可能获胜,那么分数就会低一些。可以使用一个简单的评估函数来实现这个功能。

2. 修改电脑下棋的逻辑,使其能够根据当前棋局的得分来选择最佳的下棋位置。可以使用一个循环来遍历所有可能的下棋位置,计算每个位置的得分,并选择得分最高的位置进行下棋。

下面是修改后的代码:

  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdbool.h>
  4. #include <stdlib.h>
  5. #include <time.h>

  6. void printArray(char arr[3][3])
  7. {
  8.     int i,j;
  9.     for (i=0; i<3; i++)
  10.     {
  11.         for (j=0; j<3; j++)
  12.         {
  13.             printf("%c ", arr[ i][j]);
  14.         }
  15.         printf("\n");
  16.     }
  17. }

  18. bool humanwin(char arr[3][3])
  19. {
  20.     for (int i = 0; i < 3; i++)
  21.     {
  22.         if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
  23.         {
  24.             return true;
  25.         }
  26.     }
  27.     for (int j = 0; j < 3; j++)
  28.     {
  29.         if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
  30.         {
  31.             return true;
  32.         }
  33.     }
  34.     if (arr[0][0] == 'X' && arr[1][1] == 'X' && arr[2][2] == 'X')
  35.     {
  36.         return true;
  37.     }
  38.     if (arr[0][2] == 'X' && arr[1][1] == 'X' && arr[2][0] == 'X')
  39.     {
  40.         return true;
  41.     }
  42.     return false;
  43. }

  44. bool computerwin(char arr[3][3])
  45. {
  46.     for (int i = 0; i < 3; i++)
  47.     {
  48.         if (arr[ i][0] == 'O' && arr[ i][1] == 'O' && arr[ i][2] == 'O')
  49.         {
  50.             return true;
  51.         }
  52.     }
  53.     for (int j = 0; j < 3; j++)
  54.     {
  55.         if (arr[0][j] == 'O' && arr[1][j] == 'O' && arr[2][j] == 'O')
  56.         {
  57.             return true;
  58.         }
  59.     }
  60.     if (arr[0][0] == 'O' && arr[1][1] == 'O' && arr[2][2] == 'O')
  61.     {
  62.         return true;
  63.     }
  64.     if (arr[0][2] == 'O' && arr[1][1] == 'O' && arr[2][0] == 'O')
  65.     {
  66.         return true;
  67.     }
  68.     return false;
  69. }

  70. bool nowin(char arr[3][3])
  71. {
  72.     if (arr[0][0] != '.' && arr[0][1] != '.' && arr[0][2] != '.' && arr[1][0] != '.' && arr[1][1] != '.' && arr[1][2] != '.' && arr[2][0] != '.' && arr[2][1] != '.' && arr[2][2] != '.')
  73.     {
  74.         return true;
  75.     }
  76.     else
  77.     {
  78.         return false;
  79.     }
  80. }

  81. void calculateRowAndCol(int x, int* row, int* col)
  82. {
  83.     *row = 2 - ((x-1) / 3);
  84.     *col = (x-1) % 3;
  85. }

  86. // 评估当前棋局的得分
  87. int evaluate(char arr[3][3])
  88. {
  89.     // 电脑获胜
  90.     if (computerwin(arr))
  91.     {
  92.         return 1;
  93.     }
  94.     // 人类获胜
  95.     if (humanwin(arr))
  96.     {
  97.         return -1;
  98.     }
  99.     // 平局
  100.     if (nowin(arr))
  101.     {
  102.         return 0;
  103.     }
  104.     // 其他情况
  105.     return 0;
  106. }

  107. // 电脑选择最佳下棋位置
  108. void computerMove(char arr[3][3])
  109. {
  110.     int bestScore = -1000;
  111.     int bestRow = -1;
  112.     int bestCol = -1;

  113.     // 遍历所有可能的下棋位置
  114.     for (int i = 0; i < 3; i++)
  115.     {
  116.         for (int j = 0; j < 3; j++)
  117.         {
  118.             // 如果当前位置为空
  119.             if (arr[ i][j] == '.')
  120.             {
  121.                 // 临时下棋
  122.                 arr[ i][j] = 'O';
  123.                 // 计算当前棋局的得分
  124.                 int score = evaluate(arr);
  125.                 // 撤销临时下棋
  126.                 arr[ i][j] = '.';
  127.                 // 更新最佳得分和位置
  128.                 if (score > bestScore)
  129.                 {
  130.                     bestScore = score;
  131.                     bestRow = i;
  132.                     bestCol = j;
  133.                 }
  134.             }
  135.         }
  136.     }

  137.     // 在最佳位置下棋
  138.     arr[bestRow][bestCol] = 'O';
  139.     printf("\033[2J\033[H");
  140. }

  141. int main()
  142. {
  143.     char board_now[3][3] = {{'.','.','.'},{'.','.','.'},{'.','.','.'}};
  144.     int i,x,y,row,col;
  145.     for (i=0;i<9;i++)
  146.     {
  147.         for (i=0;i<5;i++)
  148.         {
  149.             printArray(board_now);
  150.             printf("human input:");
  151.             scanf("%i",&x);
  152.             calculateRowAndCol(x, &row, &col);
  153.             if (board_now[row][col] == '.')
  154.             {
  155.                 board_now[row][col] = 'X';
  156.                 printf("\033[2J\033[H");
  157.                 break;
  158.             }
  159.             else
  160.             {
  161.                 printf("\033[2J\033[H");
  162.                 printf("you have done this.please input again.\n");
  163.                 i = i-1;
  164.             }
  165.         }
  166.         if (humanwin(board_now))
  167.         {
  168.             printArray(board_now);
  169.             printf("human win.\n");
  170.             break;
  171.         }
  172.         for (i=0;i<4;i++)
  173.         {
  174.             srand(time(NULL));
  175.             y = rand()%(9+1);
  176.             calculateRowAndCol(y, &row, &col);
  177.             if (board_now[row][col] == '.')
  178.             {
  179.                 board_now[row][col] = 'O';
  180.                 printf("\033[2J\033[H");
  181.                 break;
  182.             }
  183.             else
  184.             {
  185.                 i = i-1;
  186.                 if (nowin(board_now))
  187.                 {
  188.                     printf("nobady win.");
  189.                     break;
  190.                 }
  191.             }
  192.         }
  193.         if (computerwin(board_now))
  194.         {
  195.             printArray(board_now);
  196.             printf("computer win.\n");
  197.             break;
  198.         }  
  199.     }
  200.     return 0;
  201. }
复制代码


通过以上修改,电脑会根据当前棋局的得分来选择最佳的下棋位置,从而实现一些简单的智能。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-9 15:25:16 | 显示全部楼层    本楼为最佳答案   
要让电脑实现一些智能,可以通过以下几个步骤来修改代码:

1. 添加一个函数,用于评估当前棋局的得分。可以根据棋局的优势和劣势来给棋局打分。例如,如果电脑有可能获胜,那么分数就会高一些;如果对手有可能获胜,那么分数就会低一些。可以使用一个简单的评估函数来实现这个功能。

2. 修改电脑下棋的逻辑,使其能够根据当前棋局的得分来选择最佳的下棋位置。可以使用一个循环来遍历所有可能的下棋位置,计算每个位置的得分,并选择得分最高的位置进行下棋。

下面是修改后的代码:

  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdbool.h>
  4. #include <stdlib.h>
  5. #include <time.h>

  6. void printArray(char arr[3][3])
  7. {
  8.     int i,j;
  9.     for (i=0; i<3; i++)
  10.     {
  11.         for (j=0; j<3; j++)
  12.         {
  13.             printf("%c ", arr[ i][j]);
  14.         }
  15.         printf("\n");
  16.     }
  17. }

  18. bool humanwin(char arr[3][3])
  19. {
  20.     for (int i = 0; i < 3; i++)
  21.     {
  22.         if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
  23.         {
  24.             return true;
  25.         }
  26.     }
  27.     for (int j = 0; j < 3; j++)
  28.     {
  29.         if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
  30.         {
  31.             return true;
  32.         }
  33.     }
  34.     if (arr[0][0] == 'X' && arr[1][1] == 'X' && arr[2][2] == 'X')
  35.     {
  36.         return true;
  37.     }
  38.     if (arr[0][2] == 'X' && arr[1][1] == 'X' && arr[2][0] == 'X')
  39.     {
  40.         return true;
  41.     }
  42.     return false;
  43. }

  44. bool computerwin(char arr[3][3])
  45. {
  46.     for (int i = 0; i < 3; i++)
  47.     {
  48.         if (arr[ i][0] == 'O' && arr[ i][1] == 'O' && arr[ i][2] == 'O')
  49.         {
  50.             return true;
  51.         }
  52.     }
  53.     for (int j = 0; j < 3; j++)
  54.     {
  55.         if (arr[0][j] == 'O' && arr[1][j] == 'O' && arr[2][j] == 'O')
  56.         {
  57.             return true;
  58.         }
  59.     }
  60.     if (arr[0][0] == 'O' && arr[1][1] == 'O' && arr[2][2] == 'O')
  61.     {
  62.         return true;
  63.     }
  64.     if (arr[0][2] == 'O' && arr[1][1] == 'O' && arr[2][0] == 'O')
  65.     {
  66.         return true;
  67.     }
  68.     return false;
  69. }

  70. bool nowin(char arr[3][3])
  71. {
  72.     if (arr[0][0] != '.' && arr[0][1] != '.' && arr[0][2] != '.' && arr[1][0] != '.' && arr[1][1] != '.' && arr[1][2] != '.' && arr[2][0] != '.' && arr[2][1] != '.' && arr[2][2] != '.')
  73.     {
  74.         return true;
  75.     }
  76.     else
  77.     {
  78.         return false;
  79.     }
  80. }

  81. void calculateRowAndCol(int x, int* row, int* col)
  82. {
  83.     *row = 2 - ((x-1) / 3);
  84.     *col = (x-1) % 3;
  85. }

  86. // 评估当前棋局的得分
  87. int evaluate(char arr[3][3])
  88. {
  89.     // 电脑获胜
  90.     if (computerwin(arr))
  91.     {
  92.         return 1;
  93.     }
  94.     // 人类获胜
  95.     if (humanwin(arr))
  96.     {
  97.         return -1;
  98.     }
  99.     // 平局
  100.     if (nowin(arr))
  101.     {
  102.         return 0;
  103.     }
  104.     // 其他情况
  105.     return 0;
  106. }

  107. // 电脑选择最佳下棋位置
  108. void computerMove(char arr[3][3])
  109. {
  110.     int bestScore = -1000;
  111.     int bestRow = -1;
  112.     int bestCol = -1;

  113.     // 遍历所有可能的下棋位置
  114.     for (int i = 0; i < 3; i++)
  115.     {
  116.         for (int j = 0; j < 3; j++)
  117.         {
  118.             // 如果当前位置为空
  119.             if (arr[ i][j] == '.')
  120.             {
  121.                 // 临时下棋
  122.                 arr[ i][j] = 'O';
  123.                 // 计算当前棋局的得分
  124.                 int score = evaluate(arr);
  125.                 // 撤销临时下棋
  126.                 arr[ i][j] = '.';
  127.                 // 更新最佳得分和位置
  128.                 if (score > bestScore)
  129.                 {
  130.                     bestScore = score;
  131.                     bestRow = i;
  132.                     bestCol = j;
  133.                 }
  134.             }
  135.         }
  136.     }

  137.     // 在最佳位置下棋
  138.     arr[bestRow][bestCol] = 'O';
  139.     printf("\033[2J\033[H");
  140. }

  141. int main()
  142. {
  143.     char board_now[3][3] = {{'.','.','.'},{'.','.','.'},{'.','.','.'}};
  144.     int i,x,y,row,col;
  145.     for (i=0;i<9;i++)
  146.     {
  147.         for (i=0;i<5;i++)
  148.         {
  149.             printArray(board_now);
  150.             printf("human input:");
  151.             scanf("%i",&x);
  152.             calculateRowAndCol(x, &row, &col);
  153.             if (board_now[row][col] == '.')
  154.             {
  155.                 board_now[row][col] = 'X';
  156.                 printf("\033[2J\033[H");
  157.                 break;
  158.             }
  159.             else
  160.             {
  161.                 printf("\033[2J\033[H");
  162.                 printf("you have done this.please input again.\n");
  163.                 i = i-1;
  164.             }
  165.         }
  166.         if (humanwin(board_now))
  167.         {
  168.             printArray(board_now);
  169.             printf("human win.\n");
  170.             break;
  171.         }
  172.         for (i=0;i<4;i++)
  173.         {
  174.             srand(time(NULL));
  175.             y = rand()%(9+1);
  176.             calculateRowAndCol(y, &row, &col);
  177.             if (board_now[row][col] == '.')
  178.             {
  179.                 board_now[row][col] = 'O';
  180.                 printf("\033[2J\033[H");
  181.                 break;
  182.             }
  183.             else
  184.             {
  185.                 i = i-1;
  186.                 if (nowin(board_now))
  187.                 {
  188.                     printf("nobady win.");
  189.                     break;
  190.                 }
  191.             }
  192.         }
  193.         if (computerwin(board_now))
  194.         {
  195.             printArray(board_now);
  196.             printf("computer win.\n");
  197.             break;
  198.         }  
  199.     }
  200.     return 0;
  201. }
复制代码


通过以上修改,电脑会根据当前棋局的得分来选择最佳的下棋位置,从而实现一些简单的智能。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 00:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表