flag使用错误出现bug

bug代码

cpp 复制代码
//第一关、第二关第一次进入的时候的标记变量
int flag1 = 1, flag2 = 1;

int main() {

	while (!gameOver) {

		if (level == 1 && flag1 == 1) {
			currentpr = rk[0][0];
			currentpc = rk[0][1];
			newpr = currentpr;
			newpc = currentpc;
			flag1 = 0;
		}
		/*
			出现bug的代码
		*/
		//else if (level == 2 && flag2 == 2) {

		/*
			
		*/
		else if(level == 2 && flag2 == 1){
			currentpr = rk[1][0];
			currentpc = rk[1][1];
			newpr = currentpr;
			newpc = currentpc;
			flag2 = 0;
		}

		system("cls");//清屏
		showMap();
		showMenu();

		if (isSuccess()) {
			if (level == 1) {
				cout << "逃出成功!" << endl;
				cout << "下一关" << endl;
				cout << "是否继续游戏?(Y/N)" << endl;
				cin >> direction;
				if (direction == 'Y') {
					level++;//下一关
					continue;
				}
				else {
					cout << "游戏结束,欢迎下次游玩。" << endl;
					break;
				}
			}
			else if (level == 2) {
				cout << "逃出成功!" << endl;
				break;
			}
		}

		input();
		move();
	}
	return 0;
}

Bug 原因分析

在第二关初始化逻辑中,flag2的判断条件错误,导致第二关的初始坐标未被正确设置,进而无法移动。

具体来看这段代码:

cpp 复制代码
else if (level == 2 && flag2 == 2) {  // 条件错误
    currentpr = rk[1][0];  // 第二关入口坐标(0,2)
    currentpc = rk[1][1];
    newpr = currentpr;
    newpc = currentpc;
    flag2 = 0;
}
  • 全局变量flag2初始值为1int flag2 = 1;),但判断条件写成了flag2 == 2,导致该分支永远不会执行。
  • 因此进入第二关时,currentprcurrentpc仍保留第一关结束时的坐标(而非第二关入口(0,2)),而该坐标在map2中可能是墙壁(非空格),导致move()函数中始终触发 "回退" 逻辑,表现为无法移动。

Bug 解决方案

修正第二关初始化的flag2判断条件,将flag2 == 2改为flag2 == 1,确保第一次进入第二关时正确初始化坐标。

相关推荐
茉莉玫瑰花茶11 小时前
C++ 17 详细特性解析(5)
开发语言·c++·算法
cpp_250111 小时前
P10570 [JRKSJ R8] 网球
数据结构·c++·算法·题解
cpp_250111 小时前
P8377 [PFOI Round1] 暴龙的火锅
数据结构·c++·算法·题解·洛谷
程序员老舅11 小时前
C++高并发精髓:无锁队列深度解析
linux·c++·内存管理·c/c++·原子操作·无锁队列
划破黑暗的第一缕曙光12 小时前
[C++]:2.类和对象(上)
c++·类和对象
墨雪不会编程12 小时前
C++之【深入理解Vector】三部曲最终章
开发语言·c++
cpp_250112 小时前
P9586 「MXOI Round 2」游戏
数据结构·c++·算法·题解·洛谷
kyle~12 小时前
ROS2---QoS策略
c++·机器人·ros2
爱吃生蚝的于勒12 小时前
【Linux】进程信号之捕捉(三)
linux·运维·服务器·c语言·数据结构·c++·学习
君生我老13 小时前
C++自写list类
c++