从零学算法 (LCR 177. 撞色搭配 / 题库 260)

与 260. 只出现一次的数字 III 相同
整数数组 sockets 记录了一个袜子礼盒的颜色分布情况,其中 sockets[i] 表示该袜子的颜色编号。礼盒中除了一款撞色搭配的袜子,每种颜色的袜子均有两只。请设计一个程序,在时间复杂度 O(n),空间复杂度O(1) 内找到这双撞色搭配袜子的两个颜色编号。
示例 1:
输入:sockets = [4, 5, 2, 4, 6, 6]
输出:[2,5] 或 [5,2]
示例 2:
输入:sockets = [1, 2, 4, 1, 4, 3, 12, 3]
输出:[2,12] 或 [12,2]

  • 如果你对位运算有了一定的了解,你肯定会第一时间想到异或,因为异或运算有个特性就是 a^a = 0,所以就像连连看一样,遍历异或 [1,1,2,2,3] 以后会剩下 3。但是这一题就难在他并非只有一个单色袜,而是有两个,设他们为 x,y ,遍历异或完数组以后会剩下 x^y,记作 z,根据异或的特点可知,如果 z 的某一位为 1,那就表示 x 和 y 在那一位一个为 0 一个为 1。这也就是我们分出 x 和 y 的关键。我们就从右往左不断取 z 的某一位,看哪个是 1。用一个 m 记录,初始化为 0001,然后为 0010, 0100…。那么 x 和 y 与 m 进行 & 运算会得到不同结果,我们再遍历一遍数组就能以此得到 x 和 y 了。
  •   public int[] sockCollocation(int[] nums) {
          int x=0,y=0,z=0,m=1;
          // 遍历异或得到 z
          for(int n:nums){
              z ^=n;
          }
          // 得到用来区分 x 和 y 的 m
          while((z&m)==0)m<<=1;
          // 反正最后和 x 异或的同色袜子会被消除,所以一直异或就行了
          // 比如 m 为 0010,就把 xx0x 的同色袜子都交给 x 消除了(0010&xx0x==0),剩下的就为 x 袜子
          // 否则把 xx1x 的同色袜子都异或给 y 消除了,剩下的为 y 袜子
          for(int n:nums){
              if((n&m)==0)x^=n;
              else y^=n;
          }
          return new int[]{x,y};
      }
    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一段使用 Xilinx 的 XUartPs 库控制蓝牙模块的代码。主要流程如下: 1. 头文件包含: ``` #include "xparameters.h" #include "xuartps.h" #include <stdio.h> ``` 其中,XParameters.h 是 Xilinx 提供的一个宏定义库,用于定义硬件资源的地址和 ID 等信息,XUartPs.h 是 Xilinx 提供的串口库头文件。 2. 宏定义: ``` #define UART_DEVICE_ID XPAR_XUARTPS_0_DEVICE_ID #define HC05_BAUDRATE 1920 ``` UART_DEVICE_ID 宏定义了使用的串口设备 ID,HC05_BAUDRATE 宏定义了 HC05 蓝牙模块的波特率为 1920。 3. 变量定义: ``` XUartPs Uart_Ps; u8 Sensor_Data[2]; u8 HC05_Data[2]; ``` Uart_Ps 是串口设备的句柄,Sensor_Data 和 HC05_Data 分别用于存储超声波传感器和蓝牙模块的数据。 4. 初始化串口: ``` XUartPs_Config *Config = XUartPs_LookupConfig(UART_DEVICE_ID); Status = XUartPs_CfgInitialize(&Uart_Ps, Config, Config->BaseAddress); ``` 这里使用 XUartPs_LookupConfig 函数获取串口配置信息,然后使用 XUartPs_CfgInitialize 函数初始化串口。 5. 配置 HC05 蓝牙模块: ``` XUartPs_SetBaudRate(&Uart_Ps, HC05_BAUDRATE); XUartPs_SetLineControlReg(&Uart_Ps, XUARTPS_LCR_8_DATA_BITS); XUartPs_SetFlowControl(&Uart_Ps, 0); ``` 这里使用 XUartPs_SetBaudRate 函数设置 HC05 的波特率,使用 XUartPs_SetLineControlReg 函数设置数据位数为 8 位,使用 XUartPs_SetFlowControl 函数关闭流控制。 6. 循环读取传感器数据并发送到 HC05 蓝牙模块: ``` while (1) { // 读取超声波传感器数据 // 这里假设数据为两个字节,存储在Sensor_Data数组中 // ... // 将数据发送到HC05蓝牙模块 HC05_Data[0] = Sensor_Data[0]; HC05_Data[1] = Sensor_Data[1]; XUartPs_Send(&Uart_Ps, HC05_Data, 2); } ``` 这里采用了一个死循环,不断读取传感器数据,并将数据发送到 HC05 蓝牙模块。 总体而言,这段代码实现了一个简单的蓝牙数据传输功能,通过 XUartPs 库控制 HC05 蓝牙模块的波特率和数据格式,然后使用 XUartPs_Send 函数发送数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值