题目大意:给定一个序列,初始为空.现在我们将 1 到 N 的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上升子序列长度是多少? 题解:学会了 rope 操作. 由于是从小到大插入元素,发现当前插入 i 时,对前 i-1 个元素的答案没有影响,即:后续插入对之前的答案不造成影响,因此可以离线操作. 现在瓶颈在于如何快速构建出最终的序列形态,即:需要一种可以支持快速插入的数据结构. 这里采用 C++ 自带的数据结构 rope,插入元素到指定位置的时间复杂…