这些题目摘录自洛谷,属于典型竞赛题,涵盖模拟优化、图论性质、暴力枚举及动态规划等核心考点。通过练习这些题目,可以有效锻炼解题思路,将算法模板转化为实际代码能力。
本期涉及算法:模拟 + 优化,图的性质 + 并查集,暴力枚举 + 预处理 + 滑动窗口(优化),线性 dp,前缀和 + 哈希表 + 同余,正难则反 - 反图。
1. 寻宝
解法:模拟 + 优化
根据题意模拟爬楼过程。如果每层楼都遍历所有房间去找楼梯,时间复杂度会很高。我们可以用 cnt[i] 数组记录第 i 层楼有楼梯的房间数。对于要找的第 s 个楼梯,直接计算 s % cnt[i] 即可定位。注意取模结果为 0 时,应指向该层的最后一个符合条件的房间。
代码:
#include <iostream>
using namespace std;
typedef long long LL;
const int N = 1e4 + 10, M = 110, MOD = 20123;
LL n, m;
bool st[N][N]; // 标记楼梯信息
LL s[N][M]; // 维护指示牌信息
LL cnt[N]; // 用于优化,存第 i 楼有楼梯的房间个数
int main() {
cin >> n >> m;
for (int i = 1; i <= n; i++) {
for (int j = 0; j < m; j++) { // 注意:房间编号从 0 开始
int a, b;
cin >> a >> b;
if (a) {
st[i][j] = true;
cnt[i]++;
}
s[i][j] = b;
}
}
int pos = 0;
cin >> pos;
LL ret = 0;
( i = ; i <= n; i++) {
ret = (ret + s[i][pos]) % MOD;
LL step = s[i][pos] % cnt[i];
(!step) step = cnt[i];
() {
(st[i][pos]) step--;
(step == ) ;
pos++;
(pos == m) pos = ;
}
}
cout << ret << endl;
;
}


