Equal XOR(异或,思维)

文章目录

  • 题目描述
    • 输入格式
    • 输出格式
    • 样例输入1
    • 样例输出1
    • 样例输入2
    • 样例输出2
    • 样例输入3
    • 样例输出3
    • 提交链接
    • 提示
  • 解析
  • 参考代码

题目描述

给你一个长度为 2 ∗ n 2*n 2n 的数组 a a a ,它由 1 1 1 n n n 的每个整数组成,每个整数包含 2 2 2 次。同时给你一个整数 k ( 1 ≤ k ≤ ⌊ n 2 ⌋ ) k(1≤k≤⌊\frac{n}{2}⌋) k(1k2n⌋)

你需要找出两个长度分别为 2 ∗ k 2*k 2k 的数组 l l l r r r,使得:

  • l l l [ a 1 , a 2 , … a n ] [a_1,a_2,…a_n] [a1,a2,an] 的子集。
  • r r r [ a n + 1 , a n + 2 , . . . , a 2 n ] [a_{n+1},a_{n+2},...,a_{2n}] [an+1,an+2,...,a2n] 的子集。
  • l l l 元素的异或等于 r r r 元素的异或。换句话说: l 1 ⊕ l 2 ⊕ . . . ⊕ l 2 k = r 1 ⊕ r 2 ⊕ . . . r 2 k l_1⊕l_2⊕...⊕l_{2k}=r_1⊕r_2⊕...r_{2k} l1l2...l2k=r1r2...r2k 的子集。

至少有一对 l l l r r r 是存在的。如果有多个解,可以输出其中任意一个。

序列 x x x 是序列 y y y 的子集,如果 x x x 可以通过删除 y y y 中的几个元素(可能一个元素也没有或全部元素)并按任意顺序重新排列而得到。例如, [ 3 , 1 , 2 , 1 ] [3,1,2,1] [3,1,2,1] [ 1 , 2 , 3 ] [1,2,3] [1,2,3] [ 1 , 1 ] [1,1] [1,1] [ 3 , 2 ] [3,2] [3,2] [ 1 , 1 , 2 , 3 ] [1,1,2,3] [1,1,2,3] 的子集,但 [ 4 ] [4] [4] [ 2 , 2 ] [2,2] [2,2] 不是 [ 1 , 1 , 2 , 3 ] [1,1,2,3] [1,1,2,3] 的子集。

输入格式

第一行包含 2 2 2 个整数 n n n k k k ( 2 ≤ n ≤ 5 ⋅ 1 0 4 , 1 ≤ k ≤ ⌊ n 2 ) (2≤n≤5⋅10^4 , 1≤k≤⌊\frac{n}{2}) (2n5104,1k2n)

第二行包含 2 ∗ n 2*n 2n 个整数 a 1 , a 2 , . . . , a 2 n ( 1 ≤ a i ≤ n ) a_1,a_2,...,a_{2n}(1 \leq a_i \leq n) a1,a2,...,a2n(1ain)。保证从 1 1 1 n n n 的每个整数在 a a a 中恰好出现两次。

输出格式

输出两行。

在第一行输出中,输出 2 ∗ k 2*k 2k 个整数 l 1 , l 2 , . . . , l 2 k l_1,l_2,...,l_{2k} l1,l2,...,l2k

在第二行输出中,输出 2 ∗ k 2*k 2k 个整数 r 1 , r 2 , . . . , r 2 k r_1,r_2,...,r_{2k} r1,r2,...,r2k

如果有多个解,可以输出其中任意一个。

样例输入1

2 1
1 2 2 1

样例输出1

2 1
2 1

样例输入2

6 1
6 4 2 1 2 3 1 6 3 5 5 4

样例输出2

6 4
1 3

样例输入3

4 1
1 2 3 4 1 2 3 4

样例输出3

1 2
1 2

提交链接

https://hydro.ac/d/lp728/p/9

提示

样例解释:

样例 1 1 1 中,我们选择 l = [ 2 , 1 ] l=[2,1] l=[2,1] r = [ 2 , 1 ] r=[2,1] r=[2,1] [ 2 , 1 ] [2,1] [2,1] [ a 1 , a 2 ] [a_1,a_2] [a1,a2] 的子集, [ 2 , 1 ] [2,1] [2,1] [ a _ 3 , a _ 4 ] [a\_3,a\_4] [a_3,a_4] 的子集。 2 ⊕ 1 = 2 ⊕ 1 = 3 2⊕1=2⊕1=3 21=21=3 ,满足题意。

样例 2 2 2 中, 6 ⊕ 4 = 1 ⊕ 3 = 2 6⊕4=1⊕3=2 64=13=2 ,满足题意。

解析

根据数字在 a [ 1... n ] a[1...n] a[1...n] 中出现的次数分组。

a [ 1... n ] a[1...n] a[1...n] 中出现 0 0 0 次的数字组与在 a [ 1... n ] a[1...n] a[1...n] 中出现 2 2 2 次的数字组大小相同。(两个区间的长度一样,每个数最多出现 2 2 2 次,平均分)

我们可以将任何 2 2 2 出现的数字添加到序列 l l l 中,也可以将任何 0 0 0 出现的数字添加到序列 r r r 中,不会出现任何问题,因为 x o r xor xor 值会抵消。

我们根据需要使用尽可能多的 1 1 1 出现数追加到 l l l r r r 中。由于我们对两个序列都进行了追加, 两个序列的 x o r xor xor 值将是相同的。

参考代码

#include <bits/stdc++.h>
using namespace std;int main()
{int t;cin >> t;while (t--){int n, k;cin >> n >> k;k = 2 * k;vector <int> a(2 * n), occ(n + 1, 0);for (auto &x : a) cin >> x;for (int i = 0; i < n; i++) occ[a[i]]++;vector <int> g0, g1, g2;for (int i = 1; i <= n; i++){if (occ[i] == 0) g0.push_back(i);else if (occ[i] == 1) g1.push_back(i);else g2.push_back(i);}int v = 0;for (auto x : g2){if (v < k){v += 2;cout << x << " " << x << " ";}}for (auto x : g1){if (v < k){v++;cout << x << " ";}}cout << "\n";v = 0;for (auto x : g0){if (v < k){v += 2;cout << x << " " << x << " ";}}for (auto x : g1){if (v < k){v++;cout << x << " ";}}cout << "\n";}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/844605.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nodejs版本管理切换工具nvm介绍、nvm下载、nvm安装、配置及nvm使用

最近很多同学问&#xff0c;在工作中&#xff0c;同时在进行2个或者多个不同的项目开发&#xff0c;每个项目的需求不同&#xff0c;进而不同项目必须依赖不同版本的NodeJS运行环境&#xff0c;这种情况下&#xff0c;对于维护多个版本的node将会是一件非常麻烦的事情&#xff…

SQL刷题笔记day6-1

1从不订购的客户 分析&#xff1a;从不订购&#xff0c;就是购买订单没有记录&#xff0c;not in 我的代码&#xff1a; select c.name as Customers from Customers c where c.id not in (select o.customerId from Orders o) 2 部门工资最高的员工 分析&#xff1a;每个部…

vue+elemntui 加减表单框功能样式

<el-form ref"form" :model"form" :rules"rules" label-width"80px"><el-form-item label"配置时间" prop"currentAllocationDate"><div v-for"(item,key) in timeList"><el-date…

高并发项目-用户登录基本功能

文章目录 1.数据库表设计1.IDEA连接数据库2.修改application.yml中数据库的名称为seckill3.IDEA创建数据库seckill4.创建数据表 seckill_user5.密码加密分析1.传统方式&#xff08;不安全&#xff09;2.改进方式&#xff08;两次加密加盐&#xff09; 2.密码加密功能实现1.pom.…

CI/CD(基于ESP-IDF)

主要参考资料 B站乐鑫信息科技《【乐鑫全球开发者大会】DevCon23 #15 &#xff5c;通过 CI/CD 进行流水线开发》 pytest-embedded乐鑫文档: https://docs.espressif.com/projects/pytest-embedded/en/latest/api.html 目录 CI/CD简介乐鑫内部CI/CD测试GitLab CI/CDGitHub Actio…

CSA 实现安全应用容器架构的最佳实践 课堂随笔

CSA 实现安全应用容器架构的最佳实践 编写背景 随着云计算和微服务架构的兴起&#xff0c;容器技术因其轻量级、可移植性和易于管理等优势成为现代应用部署的首选。然而&#xff0c;容器的安全性问题也随之凸显。云安全联盟&#xff08;Cloud Security Alliance, CSA&#xf…

Android基础-Kotlin语言的作用及优缺点

一、Kotlin语言的作用 Kotlin是一种由JetBrains公司开发的现代化静态类型编程语言&#xff0c;自其诞生以来&#xff0c;便在多个领域展现出了强大的应用潜力。其主要作用可以概括为以下几点&#xff1a; Android应用开发&#xff1a;Kotlin作为Android开发的官方推荐语言&am…

dockerfile关键字

参考&#xff1a;59_Dockerfile保留字简介_哔哩哔哩_bilibili FROM 作用&#xff1a;指定基础镜像&#xff0c;即在这个基础镜像上构建新镜像&#xff0c;如下所示&#xff0c;表示在ubuntu20.04镜像的基础上构建新镜像 FROM ubuntu:20.04 MAINTAINER 作用&#xff1a;镜像…

LabVIEW中实现Trio控制器的以太网通讯

在LabVIEW中实现与Trio控制器的以太网通讯&#xff0c;可以通过使用TCP/IP协议来完成。这种方法包括配置Trio控制器的网络设置、使用LabVIEW中的TCP/IP函数库进行数据传输和接收&#xff0c;以及处理通讯中的错误和数据解析。本文将详细说明实现步骤&#xff0c;包括配置、编程…

SheetJS V0.17.5 导入 Excel 异常修复 Invalid HTML:could not find<table>

导入 Excel 提示错误&#xff1a;Invalid HTML:could not find<table> 检查源代码 发现 table 属性有回车符 Overview: https://docs.sheetjs.com/docs/ Source: https://git.sheetjs.com/sheetjs/sheetjs/issues The public-facing websites of SheetJS: sheetjs.com…

网络通讯聊天工具的实现v2

在原有基础上加入文件的传输功能。 从客户端传送到服务器后&#xff0c;服务器接受文件&#xff0c;再转发给其他客户端&#xff0c;客户端接受后服务器删除文件。 涉及文件的读取与关闭。 1.原来传输的改进 1.1服务器需要区分传输的是文件还是信息。 在传输之前先传输一个…

Linux基础指令用户管理002

继Linux基础指令用户管理001我们讲述了创建用户和删除用户&#xff0c;我们讲一下如何设置用户密码以及修改用户信息。 操作系统 CentOS Stream 9 设置用户密码 我们使用passwd指令passwd name [rootlocalhost ~]# passwd wg 更改用户 wg 的密码 。 新的密码&#xff1a; …

装机必备——截图软件PixPin安装教程

装机必备——截图软件PixPin安装教程 软件下载 软件名称&#xff1a;PixPin 1.5 软件语言&#xff1a;简体中文 软件大小&#xff1a;30.1M 系统要求&#xff1a;Windows7或更高&#xff0c; 64位操作系统 硬件要求&#xff1a;CPU2GHz &#xff0c;RAM2G或更高 下载通道①迅…

通过LLM多轮对话生成单元测试用例

通过LLM多轮对话生成单元测试用例 代码 在采用 随机生成pytorch算子测试序列且保证算子参数合法 这种方法之前,曾通过本文的方法生成算子组合测试用例。目前所测LLM生成的代码均会出现BUG,且多次交互后仍不能解决.也许随着LLM的更新,这个问题会得到解决.记录备用。 代码 impo…

Inno Setup 深入浅出-文件的显示

【1】在需要打包的文件中&#xff0c;新建一个文本文件&#xff0c;如License.txt 注意&#xff1a;中文的编码格式需要GB2312&#xff0c;否则显示乱码 【2】读取、显示文本 [Code] procedure Init_ShowLicense(); var tmpFont:TFont; begin editLicense : TMemo.C…

OpenFHE 源码解析:BinFHE 部分

参考文献&#xff1a; [ABB22] Al Badawi A, Bates J, Bergamaschi F, et al. Openfhe: Open-source fully homomorphic encryption library[C]//Proceedings of the 10th Workshop on Encrypted Computing & Applied Homomorphic Cryptography. 2022: 53-63.openfheorg/o…

算法训练营day43

题目1&#xff1a;343. 整数拆分 - 力扣&#xff08;LeetCode&#xff09; class Solution { public:int integerBreak(int n) {vector<int> dp(n 1, 0);dp[2] 1;for(int i 3;i < n;i) {for(int j 1;j < i;j ) {// j * (i - j)相当于拆分成两个数// j * dp[i …

搭建YOLOv10环境 训练+推理+模型评估

文章目录 前言一、环境搭建必要环境1. 创建yolov10虚拟环境2. 下载pytorch (pytorch版本>1.8)3. 下载YOLOv10源码4. 安装所需要的依赖包 二、推理测试1. 将如下代码复制到ultralytics文件夹同级目录下并运行 即可得到推理结果2. 关键参数 三、训练及评估1. 数据结构介绍2. 配…

kotlin基础之泛型和委托

Kotlin泛型的概念及使用 泛型概念 在Kotlin中&#xff0c;泛型&#xff08;Generics&#xff09;是一种允许在类、接口和方法中使用类型参数的技术。这些类型参数在实例化类、实现接口或调用方法时会被具体的类型所替代。泛型的主要目的是提高代码的复用性、类型安全性和可读…

oracle翻页查询的小坑记录

oracle的查询&#xff0c;因为能获取到查询结果的rownum&#xff0c;就想着直接在查询条件后面做翻页&#xff0c;而且首页确实是正常查询到了。后面才发现翻页是空的。。。 这是因为rownum排序是在查询结果才分配的。所以应该把查询结果作为子查询&#xff0c;在外查询应用排序…