总结做题时遇到的一些奇妙的技巧

1.有关平均值的一个技巧

判断一个区间\(a_n~a_m\)的平均值avg是否大于一个数b,可等价为判断前缀和数组中\(s_m\)与\(s_{n-1}\)的大小关系

证明:
\(avg = \frac{\displaystyle \sum_{n \ \leq i \ \leq \ m}a[i]}{m - n + 1}\)
\(avg - b = \frac{\displaystyle \sum_{n \ \leq i \ \leq \ m}a[i]}{m - n + 1} - b = \frac{\displaystyle \sum_{n \ \leq i \ \leq \ m}a[i] - (m - n + 1) * b}{m - n + 1}\)
因为\(m - n + 1 > 0\), 所以\(avg\)与\(b\)的大小关系等价为\(\displaystyle \sum_{n \ \leq i \ \leq \ m}a[i] - (m - n + 1) * b\)与0的大小关系,即每一个a[i]减去b之后的和与0的关系
区间求和如果采用前缀和的方式,问题又可等价为\(s_m - s_{n-1}\)与0的关系,即\(s_m\)与\(s_{n-1}\)的大小关系