天梯赛L1-087 机工士姆斯塔迪奥

发布时间 2023-05-19 23:52:52作者: 我爱软工

一、问题描述

在 MMORPG《最终幻想14》的副本“乐欲之所瓯博讷修道院”里,BOSS 机工士姆斯塔迪奥将会接受玩家的挑战。

你需要处理这个副本其中的一个机制:N×M 大小的地图被拆分为了 N×M 个 1×1 的格子,BOSS 会选择若干行或/及若干列释放技能,玩家不能站在释放技能的方格上,否则就会被击中而失败。

给定 BOSS 所有释放技能的行或列信息,请你计算出最后有多少个格子是安全的。

输入格式:

输入第一行是三个整数 N,M,Q (1N×M105,0Q1000),表示地图为 N 行 M 列大小以及选择的行/列数量。

接下来 Q 行,每行两个数 Ti,Ci,其中 Ti=0 表示 BOSS 选择的是一整行,Ti=1 表示选择的是一整列,Ci 为选择的行号/列号。行和列的编号均从 1 开始。

输出格式:

输出一个数,表示安全格子的数量。

输入样例:

5 5 3
0 2
0 4
1 3
 

输出样例:

12

二、设计思路

(1)先从键盘接收格子的行数n和列数m以及boss攻击的次数q;

(2)定义一个二维整型数组,初始值全部置为0;

(3)利用for循环接收q次数据,定义flag来判断boss攻击的是列还是行(flag==0时表示攻击的是行,flag==1时表示攻击的是列);

(4)利用for循环,将每个被攻击的格子对应的位置数组的值执行++操作;

(5)对二维整型数组中的元素进行遍历,如果值为0(安全),对应计数器count++;

(6)最后对count进行输出(count表示的就是安全的格子的总数);

三、程序流程图

 

四、伪代码

五、代码

 1 #include <iostream>
 2 using namespace std;
 3 int main()
 4 {
 5     int n, m, q;
 6     cin >> n >> m >> q;
 7     int a[100][100];
 8     int flag = 0;      //选择行还是列
 9     int count = 0;    //剩下的安全格子
10     int x = 0;
11     for (int i = 0; i < n; i++)
12     {
13         for (int j = 0; j < m; j++)
14         {
15             a[i][j] = 0;
16         }
17     }
18     for (int i = 0; i < q; i++)
19     {
20         cin >> flag;
21         cin >> x;
22         if (flag == 0)
23         {
24             for (int i = 0; i < m; i++)
25             {
26                 a[x - 1][i]++;
27             }
28         }
29         else if (flag == 1)
30         {
31             for (int j = 0; j < n; j++)
32             {
33                 a[j][x - 1]++;
34             }
35         }
36     }
37     for (int i = 0; i < n; i++)
38     {
39         for (int j = 0; j < m; j++)
40         {
41             if (a[i][j] == 0)
42             {
43                 count++;
44             }
45         }
46     }
47     cout << count << endl;
48     return 0;
49 }

运行结果:

 

六、总结

(1)对于某一个变量的值,如果值不同对于的操作方法不同,将这个变量作为标志值,一个值对应一种情况;

(2)可以定义一个计数器来记录满足某项要求的个数;