题意:一个w*h的玻璃,如今水平或竖直切n次(“H”表示水平切,“V”表示竖直切),每一次切后输出当前切成的块中的最大面积。
思路:用set记录分割的位置(要用两个set,分别来记录长和宽),multiset记录某一条边被切后 所得到的 小段的长度(也要两个,分别记录长和宽的)。
那么每次切后就从multiset中取出最大的长和宽,相乘即得面积。
STL set 写法
代码:
#include #include #include #include #include #include #include
并查集写法
思路:并查集初始化。首先将玻璃所有切成1*1的小块,然后先保存下所有的操作,记录下它切了哪些位置(数组vis_w和vis_h),接着将没有被切的位置 i 连起来Union(i,i+1)。最后倒着把要切的位置连起来,这个过程中记录每次两条边的最大值,它们的乘积保存下来就是答案。
代码:
#include #include #include #include #include #include #include