九宫格(C语言实现)

题目:把1、2、3、4、5、6、7、8、9、九个数放在九宫格内,使每一横行、纵行、对角线的三个数字和相等。

 

思路:第一种思路:对9个数进行全排列,依次放入宫格中,看是否符号条件
         第二种思路:试探的放入,放入一个后判断放入后符不符合要求,不符合再退回上一步

 

 

感觉这两种思路做出来的效率有点低

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是一个简单的 C 语言代码实现九宫拼图的例子: ``` #include <stdio.h> #include <stdlib.h> #include <time.h> #define SIZE 3 // 拼图大小 void init_board(int board[][SIZE]); // 初始化棋盘 void shuffle_board(int board[][SIZE]); // 洗牌 void print_board(int board[][SIZE]); // 打印棋盘 int is_win(int board[][SIZE]); // 判断是否获胜 void move(int board[][SIZE], int direction); // 移动棋子 int main() { int board[SIZE][SIZE]; int direction; char input; srand(time(NULL)); // 随机种子 init_board(board); // 初始化棋盘 shuffle_board(board); // 洗牌 while (!is_win(board)) { print_board(board); printf("请输入移动方向(上:w,下:s,左:a,右:d):"); scanf(" %c", &input); switch (input) { case 'w': direction = 1; break; case 's': direction = 2; break; case 'a': direction = 3; break; case 'd': direction = 4; break; default: printf("无效的输入!\n"); continue; } move(board, direction); } printf("恭喜你获胜!\n"); return 0; } void init_board(int board[][SIZE]) { int i, j; for (i = 0; i < SIZE; i++) { for (j = 0; j < SIZE; j++) { board[i][j] = i * SIZE + j + 1; } } board[SIZE - 1][SIZE - 1] = 0; // 最后一个子为空白 } void shuffle_board(int board[][SIZE]) { int i, j, k; for (k = 0; k < 1000; k++) { // 洗牌1000次 i = rand() % SIZE; j = rand() % SIZE; if (board[i][j] == 0) { // 空白子不动 k--; continue; } switch (rand() % 4) { // 随机选择一个方向 case 0: // 上 if (i > 0) { board[i][j] ^= board[i - 1][j] ^= board[i][j] ^= board[i - 1][j]; } break; case 1: // 下 if (i < SIZE - 1) { board[i][j] ^= board[i + 1][j] ^= board[i][j] ^= board[i + 1][j]; } break; case 2: // 左 if (j > 0) { board[i][j] ^= board[i][j - 1] ^= board[i][j] ^= board[i][j - 1]; } break; case 3: // 右 if (j < SIZE - 1) { board[i][j] ^= board[i][j + 1] ^= board[i][j] ^= board[i][j + 1]; } break; } } } void print_board(int board[][SIZE]) { int i, j; printf("\n"); for (i = 0; i < SIZE; i++) { for (j = 0; j < SIZE; j++) { if (board[i][j] == 0) { printf(" "); // 空白子用三个空表示 } else { printf("%2d ", board[i][j]); } } printf("\n"); } } int is_win(int board[][SIZE]) { int i, j; for (i = 0; i < SIZE; i++) { for (j = 0; j < SIZE; j++) { if (board[i][j] != i * SIZE + j + 1) { return 0; // 棋子未排列完成 } } } return 1; // 棋子已排列完成 } void move(int board[][SIZE], int direction) { int i, j, x, y; for (i = 0; i < SIZE; i++) { for (j = 0; j < SIZE; j++) { if (board[i][j] == 0) { // 找到空白子的位置 x = i; y = j; break; } } } switch (direction) { case 1: // 上 if (x > 0) { board[x][y] ^= board[x - 1][y] ^= board[x][y] ^= board[x - 1][y]; } else { printf("无效的移动!\n"); } break; case 2: // 下 if (x < SIZE - 1) { board[x][y] ^= board[x + 1][y] ^= board[x][y] ^= board[x + 1][y]; } else { printf("无效的移动!\n"); } break; case 3: // 左 if (y > 0) { board[x][y] ^= board[x][y - 1] ^= board[x][y] ^= board[x][y - 1]; } else { printf("无效的移动!\n"); } break; case 4: // 右 if (y < SIZE - 1) { board[x][y] ^= board[x][y + 1] ^= board[x][y] ^= board[x][y + 1]; } else { printf("无效的移动!\n"); } break; default: printf("无效的移动!\n"); break; } } ``` 这个例子使用了一个 3x3 的棋盘,初始化时将数字 1-9 放入相应的位置,然后洗牌,最后通过移动棋子使其重新排列。在输入移动方向时,w、s、a、d 分别表示上、下、左、右。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值