第四题 int n1, n2, q; int main() { cin >> n1 >> n2 >> q; vector<int> q1; vector<int> q2; vector<bool> vis(n1+n2+1,false); for (int i = 1; i <= n1; i++) { q1.push_back(i); vis[i] = false; } for (int i = n1+1; i <= n1+n2; i++) { q2.push_back(i); vis[i] = true; } int a; for (int i = 0; i < q; i++) { cin >> a ; if (!vis[a]) { q2.push_back(a); vis[a] = true; } else { q1.push_back(a); vis[a] = false; } } vector<bool> vis1(n1 + n2 + 1, false); vector<int> c1; for (int k = q1.size()-1; k>=0; k--) { if (!vis[q1[k]] && !vis1[q1[k]]) { vis1[q1[k]] = true; c1.push_back(q1[k]); } } vector<bool> vis2(n1 + n2 + 1, false); vector<int> c2; for (int k = q2.size() - 1; k >= 0; k--) { if (vis[q2[k]] && !vis2[q2[k]]) { vis2[q2[k]] = true; c2.push_back(q2[k]); } } for (int k = c1.size() - 1; k >= 0; k--) { cout << c1[k] << " "; } cout << endl; for (int k = c2.size() - 1; k >= 0; k--) { cout << c2[k] << " "; } return 0; }
点赞 评论

相关推荐

不愿透露姓名的神秘牛友
07-09 16:15
我应届生,去年10月份开始在这家公司实习,到今年10月份正好一年想(实习+试用期),在想要不要提前9月份就离职,这样好找工作些,但又差一个月满一年,又怕10月份国庆回来离职,容易错过了下半年的金九银十,到年底容易gap到年后
小破站_程序员YT:说这家公司不好吧,你干了快一年 说这家公司好吧,你刚毕业就想跑路说你不懂行情吧,你怕错过金九银十说 你懂行情吧,校招阶段在实习,毕业社招想换工作 哥们,我该怎么劝你留下来呢
应届生,你找到工作了吗
点赞 评论 收藏
分享
05-29 09:02
门头沟学院 Java
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务