数据结构---set篇
创始人
2024-05-14 11:23:36
0

在这里插入图片描述
第一次超时是因为用memsetmemsetmemset不得不超时,第二次超时是我用vectorvectorvector数组的时候,然后以O(n)O(n)O(n)复杂度查找元素之后使用eraseeraseerase方法进行删除,第三次超时是我把查找元素改成了O(logn)O(logn)O(logn)之后用vectorvectorvector的eraseeraseerase进行删除,ACACAC是我使用setsetset数据结构。
后来经过查阅资料:
在这里插入图片描述
在vectorvectorvector当中删除元素需要经过内存的O(n)O(n)O(n)拷贝,而setsetset远远不用,利用红黑树维护的话最大也是O(logn)O(logn)O(logn),找到位置,,再旋转,OhOhOh,我又想起那段实现红黑树可怕的日子。
关于这个题,我一开始想从前向后贪心,但是这会涉及到一个问题,前面如果都放小的,那么到最后把大的放后面,可能无解。所以从后往前贪心呗。参考:题解
代码:

#include
#include
#include
#include
#include
using namespace std;
const int length = 2e5 + 5;
int num[length];
int main(void)
{int t;scanf_s("%d", &t);for (int i = 0; i < t; i++){int n;scanf_s("%d", &n);int flag = 1;set tmp;for (int i = 1; i <= n; i++)tmp.insert(i);for (int i = 1; i <= n/2; i++){scanf_s("%d", &num[i]);tmp.erase(num[i]);}if (tmp.size() != n / 2){printf("-1\n");continue;}vector res;for (int i=n/2 ; i >= 1; i--){auto p = tmp.lower_bound(num[i]);if (p == tmp.begin()){flag = 0;break;}int yh = *(--p);res.insert(res.end(), { num[i],yh });tmp.erase(p);}if (flag == 0){printf("-1\n");continue;}for (int i = n-1; i >= 0; i--){printf("%d ", res[i]);}printf("\n");}
}

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...
苏州离哪个飞机场近(苏州离哪个... 本篇文章极速百科小编给大家谈谈苏州离哪个飞机场近,以及苏州离哪个飞机场近点对应的知识点,希望对各位有...