```cpp #include <iostream> #include <vector> // 定义方块世界的大小 const int WORLD_WIDTH = 10; const int WORLD_HEIGHT = 10; // 定义玩家的位置 int playerX = 0; int playerY = 0; // 定义方块世界 std::vector<std::vector<char>> world(WORLD_HEIGHT, std::vector<char>(WORLD_WIDTH, '.')); // 打印当前的世界状态 void printWorld() { for (int y = 0; y < WORLD_HEIGHT; ++y) { for (int x = 0; x < WORLD_WIDTH; ++x) { if (x == playerX && y == playerY) { std::cout << 'P'; // 玩家位置 } else {
分析这段代码,整体逻辑清晰,功能实现了一个简单的方块世界中玩家移动的功能,但有一些可以优化和值得注意的地方。 优化建议 1. 代码结构方面:可以将玩家的位置信息封装成一个类,提高代码的可维护性和可扩展性。 2. 输入验证方面:除了判断输入是否是`w`、`s`、`a`、`d`、`q`,还可以处理一些非法输入字符,增强程序健壮性。 3. 代码复用性:可以将世界的打印和玩家移动逻辑的合法性检查封装成更通用的函数。 优化后的代码 ```cpp #include <iostream> #include <vector> // 定义方块世界的大小 const int WORLD_WIDTH = 10; const int WORLD_HEIGHT = 10; // 定义玩家类,封装玩家位置信息 class Player { public: int x; int y; Player() : x(0), y(0) {} }; // 定义方块世界 std::vector<std::vector<char>> world(WORLD_HEIGHT, std::vector<char>(WORLD_WIDTH, '.')); // 打印当前的世界状态 void printWorld(const Player& player) { for (int y = 0; y < WORLD_HEIGHT; ++y) { for (int x = 0; x < WORLD_WIDTH; ++x) { if (x == player.x && y == player.y) { std::cout << 'P'; // 玩家位置 } else { std::cout << world[y][x]; } } std::cout << std::endl; } } // 检查新位置是否在世界范围内 bool isValidPosition(int x, int y) { return x >= 0 && x < WORLD_WIDTH && y >= 0 && y < WORLD_HEIGHT; } // 处理玩家的移动 void movePlayer(Player& player, char direction) { int newX = player.x; int newY = player.y; switch (direction) { case 'w': // 向上移动 newY--; break; case 's': // 向下移动 newY++; break; case 'a': // 向左移动 newX--; break; case 'd': // 向右移动 newX++; break; default: std::cout << "无效的输入,请输入 w, s, a 或 d。" << std::endl; return; } // 检查新位置是否在世界范围内 if (isValidPosition(newX, newY)) { player.x = newX; player.y = newY; } else { std::cout << "不能移动到世界外面。" << std::endl; } } int main() { Player player; char input; while (true) { printWorld(player); std::cout << "输入移动方向 (w: 上, s: 下, a: 左, d: 右, q: 退出): "; std::cin >> input; if (input == 'q') { break; } movePlayer(player, input); } return 0; } ``` 需要小心的地方 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 输入验证尽量全面,除了基本的移动和退出指令的验证,还需要考虑输入非字符等特殊情况。 2. 对于边界检查,要确保在修改世界大小时,边界检查的条件也能正确更新。 3. 在封装类和函数时,要注意传参的正确性,避免传递无效的引用或指针。 [2025-12-20 19:47:37 | AI写代码神器 | 881点数解答]
- [字节豆包] ```cpp #include <iostream> #include <vector> // 定义方块世界的大小 const int WORLD_WIDTH = 10; const int WORLD_HEIGHT = 10; // 定义玩家的位置 int playerX = 0; int playerY = 0; // 定义方块世界 std::vector<std::vector<char>> world(WORLD_HEIGHT, std::vector<char>(WORLD_WIDTH, '.')); // 打印当前的世界状态 void printWorld() { for (int y = 0; y < WORLD_HEIGHT; ++y) { for (int x = 0; x < WORLD_WIDTH; ++x) { if (x == playerX && y == playerY) { std::cout << 'P'; // 玩家位置 } else { (881点数解答 | 2025-12-20 19:47:37)34
- [讯飞星火] 快速排序:# include< iostream>using namespace std;# include< stdlib. h># include< time. h>const int n =10;const int min= 10;const int max=99;int getrand( int min, int max){return ( rand()%( max-min+1)+ min);}void set( int r[], int n){int i;for(i=0;i<n;i++)r[i]=getrand(min, max);}void show( int r[], int n){int i;for(i=0;i<n;i++)cout << r[i]<<" ";cout << endl;}int partition( int r[], int i, int j){//由你完成}void quicksort( int r[], int i, int j){//由你完成}int main(){srand( time(0));int a[n];set(a, n);cout<<"(710点数解答 | 2024-11-14 10:44:25)331
- [阿里通义] 快速排序:# include< iostream>using namespace std;# include< stdlib. h># include< time. h>const int n =10;const int min= 10;const int max=99;int getrand( int min, int max){return ( rand()%( max-min+1)+ min);}void set( int r[], int n){int i;for(i=0;i<n;i++)r[i]=getrand(min, max);}void show( int r[], int n){int i;for(i=0;i<n;i++)cout << r[i]<<" ";cout << endl;}int partition( int r[], int i, int j){//由你完成}void quicksort( int r[], int i, int j){//由你完成}int main(){srand( time(0));int a[n];set(a, n);cout<<"(951点数解答 | 2024-11-14 10:46:29)314
- [字节豆包] 快速排序:# include< iostream>using namespace std;# include< stdlib. h># include< time. h>const int n =10;const int min= 10;const int max=99;int getrand( int min, int max){return ( rand()%( max-min+1)+ min);}void set( int r[], int n){int i;for(i=0;i<n;i++)r[i]=getrand(min, max);}void show( int r[], int n){int i;for(i=0;i<n;i++)cout << r[i]<<" ";cout << endl;}int partition( int r[], int i, int j){//由你完成}void quicksort( int r[], int i, int j){//由你完成}int main(){srand( time(0));int a[n];set(a, n);cout<<"(472点数解答 | 2024-11-14 10:51:44)308
- [字节豆包] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n =10; const int min =10; const int max =99; int getrand(int min, int max) { return (rand() % (max - min +1) + min); void set(int r[], int n){ int i; for(i = 0; i< n; i++) r[i] = getrand(min,max); void show(int r[], int n) { int i; for (i = 0; i<n;i++) cout << r[i] << ""; cout << endl;}void sift(int r[],int m,int k){ } void heapsort(intr[], int n){ //由你完成 int main(){ srand(time(0)); int a[n]; set(a,n); cout <<"原序(417点数解答 | 2024-11-28 11:20:23)363
- [字节豆包] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n =10; const int min =10; const int max =99; int getrand(int min, int max) { return (rand() % (max - min +1) + min); void set(int r[], int n){ int i; for(i = 0; i< n; i++) r[i] = getrand(min,max); void show(int r[], int n) { int i; for (i = 0; i<n;i++) cout << r[i] << ""; cout << endl; void heapsort(intr[], int n){ //由你完成 int main(){ srand(time(0)); int a[n]; set(a,n); cout <<"原序列:"; show(a,n); cout <<"新序列:\n"; h(684点数解答 | 2024-11-28 11:21:15)311
- [阿里通义] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n=10; const int min=10; const int max=99; int getrand(inmin,int max) { return (rand()%(max-min+1)+min); void set(int r[],int n) { int i; for(i=0; i<n; i++) r[i]=getrand(min,max); void show(intr[],int n){ int i; for(i=0; i<n; i++) cout<<r[i]<<""; cout<<endl; void insertsort(int r[],int n){//由你完成} int main() { srand(time(0)); int a[n]; set(a,n); cout<<"原序列:"; show(a,n); cout<<"新序列: \n; insertsort(a,n);//show(a,n);(690点数解答 | 2024-10-31 10:11:20)319
- [字节豆包] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n=10; const int min=10; const int max=99; int getrand(inmin,int max) { return (rand()%(max-min+1)+min); void set(int r[],int n) { int i; for(i=0; i<n; i++) r[i]=getrand(min,max); void show(intr[],int n){ int i; for(i=0; i<n; i++) cout<<r[i]<<""; cout<<endl; void insertsort(int r[],int n){//由你完成} int main() { srand(time(0)); int a[n]; set(a,n); cout<<"原序列:"; show(a,n); cout<<"新序列: \n; insertsort(a,n);//show(a,n);(147点数解答 | 2024-10-31 10:29:38)324
- [讯飞星火] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n=10; const int min=10; const int max=99; int getrand(inmin,int max) { return (rand()%(max-min+1)+min); void set(int r[],int n) { int i; for(i=0; i<n; i++) r[i]=getrand(min,max); void show(intr[],int n){ int i; for(i=0; i<n; i++) cout<<r[i]<<""; cout<<endl; void insertsort(int r[],int n){//由你完成} int main() { srand(time(0)); int a[n]; set(a,n); cout<<"原序列:"; show(a,n); cout<<"新序列: \n; insertsort(a,n);//show(a,n);(703点数解答 | 2024-10-31 10:35:24)306
- [阿里通义] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n=10; const int min=10; const int max=99; int getrand(inmin,int max) { return (rand()%(max-min+1)+min); void set(int r[],int n) { int i; for(i=0; i<n; i++) r[i]=getrand(min,max); void show(intr[],int n){ int i; for(i=0; i<n; i++) cout<<r[i]<<""; cout<<endl; void shellsort(int r[],int n){//由你完成} int main() { srand(time(0)); int a[n]; set(a,n); cout<<"原序列:"; show(a,n); cout<<"新序列: \n; shellsort(a,n);//show(a,n); re(593点数解答 | 2024-10-31 10:39:07)344
- [字节豆包] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n=10; const int min=10; const int max=99; int getrand(inmin,int max) { return (rand()%(max-min+1)+min); void set(int r[],int n) { int i; for(i=0; i<n; i++) r[i]=getrand(min,max); void show(intr[],int n){ int i; for(i=0; i<n; i++) cout<<r[i]<<""; cout<<endl; void shellsort(int r[],int n){//由你完成} int main() { srand(time(0)); int a[n]; set(a,n); cout<<"原序列:"; show(a,n); cout<<"新序列: \n; shellsort(a,n);//show(a,n); re(407点数解答 | 2024-10-31 11:04:08)273
- [字节豆包] #include<iostream> using namespace std;#include<stdlib.h>#include<time.h> const int n=10; const int min=10; const int max=99; int getrand(inmin,int max) { return (rand()%(max-min+1)+min); void set(int r[],int n) { int i; for(i=0; i<n; i++) r[i]=getrand(min,max); void show(intr[],int n){ int i; for(i=0; i<n; i++) cout<<r[i]<<""; cout<<endl; void shellsort(int r[],int n){//补充代码,显示新序列排序每一趟过程 int main() { srand(time(0)); int a[n]; set(a,n); cout<<"原序列:"; show(a,n); cout<<"新序列: \n; shellsort(a,n);//s(448点数解答 | 2024-10-31 11:07:15)233