这道题分为两个部分 Part1 前置芝士 前缀和(后缀和,二维前缀和):可以预处理一下数据. 二分查找:可以在较短的时间内找出答案. 具体做法 可以发现\(R,C\)不大,只有\(200\),于是可以先预处理出一个数组\(a[i][j][k]\),表示从\((1,1)\)~\((i,j)\)中高度为k的书出现的次数,也可以理解为一个二维前缀和,考虑贪心,所以肯定是会优先去拿高的书,于是需要再处理两个数组\(b[i][j][k]\),表示\((1,1)\)~\((i,j)\)中高度在\(k\)~\…