leetcode 3314(位运算,lowbit)

3314: 构造最小位运算数组Ⅰ

思路1:枚举

class Solution { public: vector<int> minBitwiseArray(vector<int>& nums) { vector<int> ans(nums.size(),-1); for(int i=0;i<nums.size();i++){ int x=nums[i]; for(int j=1;j<x;j++){ int y=j|(j+1); if(y==x){ ans[i]=j; break; } } } return ans; } };

思路2:位运算,lowbit

特别地,只包含最小元素的子集,即二进制最低1及其后面的 0,也叫 lowbit,可以用s&-s算出。

正数:原码 = 反码 = 补码

s = 101100 ~s = 010011 //按位取反(反码) (~s)+1 = 010100 //补码=反码+1(负数,符号位为1) s & -s = 000100 //lowbit

例如 x=100111,那么 x ∣ (x+1)=100111 ∣ 101000=101111。

可以发现,x ∣ (x+1) 的本质是把二进制最右边的 0 置为 1。

反过来,如果已知 x ∣ (x+1)=101111,那么倒推 x,需要把 101111 中的某个 1 变成 0。满足要求的 x 有:100111 101011 101101 101110
其中最小的是 100111,也就是把 101111 最右边的 0 的右边的 1 置为 0。

无解的情况:由于 x ∣ (x+1) 最低位一定是 1(因为 x 和 x+1 中必有一奇数),所以如果 nums[i] 是偶数(质数中只有 2),那么无解。

对本题:把101111取反(~x),得 010000,其 lowbit=10000 (t&-t),右移一位得 1000。把 101111 与 1000 异或,即可得到 100111。

class Solution { public: vector<int> minBitwiseArray(vector<int>& nums) { vector<int> ans(nums.size(),-1); for(int i=0;i<nums.size();i++){ int x=nums[i]; if(x==2) continue; int t=~x,s=(t&-t)>>1; //右移一位 ans[i]=x^s; //按位异或 } return ans; } };

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

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

相关文章

risc-v五级流水线cpu用于PLC系统的完整指南

用RISC-V五级流水线CPU重塑PLC&#xff1a;从架构原理到工业实战当传统PLC遇到性能瓶颈在现代工厂的控制柜里&#xff0c;一台台PLC默默执行着逻辑判断、信号采集与设备联动。但如果你拆开那些“服役”多年的控制器&#xff0c;可能会惊讶地发现&#xff1a;它们的核心仍是上世…

LED显示屏尺寸大小测量错误导致控制卡异常?一文说清

一块LED屏显示歪了&#xff1f;别急着换控制卡&#xff0c;先检查这个参数你有没有遇到过这样的情况&#xff1a;新装的LED大屏&#xff0c;画面一播放&#xff0c;左边挤成一团&#xff0c;右边却拉得老长&#xff1b;或者文字刚出来就缺了一角&#xff0c;怎么调内容都没用。…

聚焦组织效能:互联网高速增长期 HR 系统的核心选择标准

在互联网行业&#xff0c;高速增长是企业发展的常见状态&#xff0c;但随之而来的是组织架构频繁调整、人员规模快速扩张、跨部门协同难度增加等组织管理难题。传统人工或基础 HR 工具往往难以应对这些挑战&#xff0c;此时选择适配的 HR 系统就成为关键。本文围绕 “互联网公司…

高考模拟阅读理解题目:《民族》

民族 一、雾锁江城 汉口码头的雾&#xff0c;是灰黄色的&#xff0c;稠得像熬了整夜的米汤。 我紧了紧西装外套&#xff0c;初冬的江风裹着水汽&#xff0c;往衣领里钻。身后的苦力正从“江安轮”上卸下我的货——二十箱福建安溪的铁观音&#xff0c;茶叶箱上“旧金山陈氏茶行”…

GEO战略新纪元:2026年,执行之外更需顶层咨询 从算法执行到战略规划——AI搜索时代的企业生存法则

GEO战略新纪元&#xff1a;2026年&#xff0c;执行之外更需顶层咨询从算法执行到战略规划——AI搜索时代的企业生存法则当AI成为用户获取信息的首要入口&#xff0c;GEO已不再是单纯的技术优化&#xff0c;而是决定企业未来十年生死存亡的核心战略。本文深度解析2026年GEO战略咨…

Xilinx FPGA中USB3.0物理层接口调试核心要点

Xilinx FPGA中USB3.0物理层接口调试实战&#xff1a;从链路训练到信号完整性的深度突破 在高速数据采集系统日益普及的今天&#xff0c;USB3.0&#xff08;SuperSpeed USB&#xff09;凭借其5 Gbps的理论带宽&#xff0c;已成为工业相机、医疗成像设备和测试仪器中的标配接口。…

新手前端别慌:3天搞懂CSS写在哪,页面立马不丑了(附避坑指南)

新手前端别慌&#xff1a;3天搞懂CSS写在哪&#xff0c;页面立马不丑了&#xff08;附避坑指南&#xff09;新手前端别慌&#xff1a;3天搞懂CSS写在哪&#xff0c;页面立马不丑了&#xff08;附避坑指南&#xff09;先骂两句&#xff0c;再开始讲课CSS 是啥&#xff1f;——网…

三极管开关电路与逻辑电平匹配仿真设计实践指南

三极管开关电路与逻辑电平匹配&#xff1a;从原理到仿真的实战设计在嵌入式系统和数字接口设计中&#xff0c;一个看似简单却无处不在的“小角色”——三极管&#xff0c;常常承担着关键任务。你是否曾遇到这样的问题&#xff1a;3.3V的MCU GPIO口无法驱动5V继电器&#xff1f;…

图解PCB布线规则设计入门:多层板层间分布逻辑

图解PCB布线规则设计入门&#xff1a;多层板层间分布逻辑从一个“时钟抖动”问题说起某团队在调试一款基于ARM处理器的工业HMI主板时&#xff0c;发现触摸屏偶发失灵。经过示波器抓取I2C信号&#xff0c;发现SCL线上存在明显的毛刺和振铃现象。进一步排查后定位到&#xff1a;I…

Nature Sensors:国内首篇,仿生触觉新突破!清华团队研发“鸽眼”传感器,让机器人感知逼近人类!

来源&#xff1a;机器触觉前沿图1 Nature Sensors封面图&#xff0c;SuperTac在封面上展示&#xff08;右下角&#xff09;全文速览随着机器人技术从“预设程序执行”向“具身智能交互”发展&#xff0c;机器人与环境的物理交互能力成为制约其自主性与适应性的关键瓶颈。触觉感…

硬件I2C电气特性详解:上拉电阻与驱动能力

硬件I2C为何总丢包&#xff1f;揭秘上拉电阻与驱动能力的底层博弈你有没有遇到过这种情况&#xff1a;I2C代码写得严丝合缝&#xff0c;时序配置也没问题&#xff0c;可偏偏通信时不时失败——读不到传感器数据、EEPROM写入超时、RTC时间错乱。重启能好一阵&#xff0c;但干扰一…

基于广义benders分解法的综合能源系统优化规划(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&a…

线程池调度下的CPU治理

一、业务背景 在xx系统中&#xff0c;xx标签匹配模块是支撑多个下游业务的关键数据源。该模块每小时需要定时对 20万 x 1000条MVEL规则进行处理&#xff0c;涵盖&#xff1a; 标签匹配条件判断动态标签集合处理 任务采用 线程池并发处理 &#xff0c;最大并发线程数为 60 。随…

使用Vitis构建低延迟控制环路:操作指南

如何用Vitis打造微秒级响应的控制环路&#xff1f;实战全解析你有没有遇到过这样的场景&#xff1a;电机控制系统的响应总是“慢半拍”&#xff0c;哪怕算法再先进&#xff0c;动态性能也上不去&#xff1f;又或者在数字电源设计中&#xff0c;明明理论带宽足够&#xff0c;实测…

HID协议项目应用:简易游戏手柄开发教程

从零打造一个即插即用的游戏手柄&#xff1a;HID协议实战全解析 你有没有想过&#xff0c;自己动手做一个能被电脑“秒认”的游戏手柄&#xff1f;不需要装驱动、不用配对蓝牙&#xff0c;一插上USB就能在Steam或模拟器里操控角色——这听起来像是高端外设才有的体验&#xff…

大数据领域数据科学:助力企业数字化营销的策略

大数据领域数据科学&#xff1a;助力企业数字化营销的策略关键词&#xff1a;大数据、数据科学、企业数字化营销、营销策略、数据分析、用户画像、精准营销摘要&#xff1a;本文聚焦于大数据领域的数据科学如何助力企业实现数字化营销&#xff0c;通过详细介绍相关核心概念、算…

[特殊字符]_可扩展性架构设计:从单体到微服务的性能演进[20260120163651]

作为一名经历过多次系统架构演进的老兵&#xff0c;我深知可扩展性对Web应用的重要性。从单体架构到微服务&#xff0c;我见证了无数系统在扩展性上的成败。今天我要分享的是基于真实项目经验的Web框架可扩展性设计实战。 &#x1f4a1; 可扩展性的核心挑战 在系统架构演进过…

OpenAMP在边缘控制器中的实践:新手入门必看

以下是对您提供的博文《OpenAMP在边缘控制器中的实践&#xff1a;新手入门必看》进行深度润色与重构后的专业级技术文章。全文已彻底去除AI痕迹、模板化表达和空洞套话&#xff0c;转而以一位有十年嵌入式系统开发经验的工程师视角&#xff0c;用真实项目语境、踩坑总结、设计权…

单片机毕业设计最全开题分享

【单片机毕业设计项目分享系列】 &#x1f525; 这里是DD学长&#xff0c;单片机毕业设计及享100例系列的第一篇&#xff0c;目的是分享高质量的毕设作品给大家。 &#x1f525; 这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的单片机项目缺少创新和亮点…

含分布式电源的配电网日前两阶段优化调度模型(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1…