• c语言贪吃蛇游戏


    以下是一个基于 C 语言的简单贪吃蛇游戏的示例代码:

    1. #include <stdio.h>
    2. #include <conio.h>
    3. #include <windows.h>
    4. #define WIDTH 20
    5. #define HEIGHT 20
    6. int gameOver;
    7. int x, y, fruitX, fruitY, score;
    8. int tailX[100], tailY[100];
    9. int nTail;
    10. enum eDirection { STOP = 0, LEFT, RIGHT, UP, DOWN };
    11. enum eDirection dir;
    12. void Setup()
    13. {
    14. gameOver = 0;
    15. dir = STOP;
    16. x = WIDTH / 2;
    17. y = HEIGHT / 2;
    18. fruitX = rand() % WIDTH;
    19. fruitY = rand() % HEIGHT;
    20. score = 0;
    21. }
    22. void Draw()
    23. {
    24. system("cls");
    25. for (int i = 0; i < WIDTH + 2; i++)
    26. printf("#");
    27. printf("\n");
    28. for (int i = 0; i < HEIGHT; i++)
    29. {
    30. for (int j = 0; j < WIDTH; j++)
    31. {
    32. if (j == 0)
    33. printf("#");
    34. if (i == y && j == x)
    35. printf("O");
    36. else if (i == fruitY && j == fruitX)
    37. printf("F");
    38. else
    39. {
    40. int printTail = 0;
    41. for (int k = 0; k < nTail; k++)
    42. {
    43. if (tailX[k] == j && tailY[k] == i)
    44. {
    45. printf("o");
    46. printTail = 1;
    47. }
    48. }
    49. if (!printTail)
    50. printf(" ");
    51. }
    52. if (j == WIDTH - 1)
    53. printf("#");
    54. }
    55. printf("\n");
    56. }
    57. for (int i = 0; i < WIDTH + 2; i++)
    58. printf("#");
    59. printf("\n");
    60. printf("Score: %d\n", score);
    61. }
    62. void Input()
    63. {
    64. if (_kbhit())
    65. {
    66. switch (_getch())
    67. {
    68. case 'a':
    69. dir = LEFT;
    70. break;
    71. case 'd':
    72. dir = RIGHT;
    73. break;
    74. case 'w':
    75. dir = UP;
    76. break;
    77. case 's':
    78. dir = DOWN;
    79. break;
    80. case 'x':
    81. gameOver = 1;
    82. break;
    83. }
    84. }
    85. }
    86. void Logic()
    87. {
    88. int prevX = tailX[0];
    89. int prevY = tailY[0];
    90. int prev2X, prev2Y;
    91. tailX[0] = x;
    92. tailY[0] = y;
    93. for (int i = 1; i < nTail; i++)
    94. {
    95. prev2X = tailX[i];
    96. prev2Y = tailY[i];
    97. tailX[i] = prevX;
    98. tailY[i] = prevY;
    99. prevX = prev2X;
    100. prevY = prev2Y;
    101. }
    102. switch (dir)
    103. {
    104. case LEFT:
    105. x--;
    106. break;
    107. case RIGHT:
    108. x++;
    109. break;
    110. case UP:
    111. y--;
    112. break;
    113. case DOWN:
    114. y++;
    115. break;
    116. }
    117. if (x >= WIDTH)
    118. x = 0;
    119. else if (x < 0)
    120. x = WIDTH - 1;
    121. if (y >= HEIGHT)
    122. y = 0;
    123. else if (y < 0)
    124. y = HEIGHT - 1;
    125. for (int i = 0; i < nTail; i++)
    126. {
    127. if (tailX[i] == x && tailY[i] == y)
    128. {
    129. gameOver = 1;
    130. break;
    131. }
    132. }
    133. if (x == fruitX && y == fruitY)
    134. {
    135. score += 10;
    136. fruitX = rand() % WIDTH;
    137. fruitY = rand() % HEIGHT;
    138. nTail++;
    139. }
    140. }
    141. int main()
    142. {
    143. Setup();
    144. while (!gameOver)
    145. {
    146. Draw();
    147. Input();
    148. Logic();
    149. Sleep(10); // 控制游戏速度
    150. }
    151. return 0;
    152. }

    这段代码实现了一个简单的控制台贪吃蛇游戏。你可以将代码复制到 C 语言的开发环境中,如 Dev-C++、Code::Blocks 等,然后编译和运行它。请注意,此代码可能需要在 Windows 环境下运行,因为使用了 conio.h 头文件的一些函数和 windows.h 头文件的 Sleep() 函数。

  • 相关阅读:
    Maven进阶-继承与聚合
    spring事件监听与发布
    对话阿里巴巴副总裁贾扬清:追求大模型,并不是一件坏事
    代理IP和Socks5代理在游戏领域的重要应用
    文档查重,论文查重,相似度算法,pdf文档操作
    Java学习Day018(第四章数组笔记)
    分页条件搜索
    16:00面试,16:06就出来了,问的问题有点变态。。。
    如何实现制造业信息化转型?
    稳压器TPS63900DSKR 低静态电流 降压-升压转换器 应用
  • 原文地址:https://blog.csdn.net/2301_78263023/article/details/134471391