news 2026/3/2 12:45:46

LeetCode 3314.构造最小位运算数组 I:今日先简单题简单做-到II再优化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 3314.构造最小位运算数组 I:今日先简单题简单做-到II再优化

【LetMeFly】3314.构造最小位运算数组 I:今日先简单题简单做-到II再优化

力扣题目链接:https://leetcode.cn/problems/construct-the-minimum-bitwise-array-i/

给你一个长度为n的质数数组nums。你的任务是返回一个长度为n的数组ans,对于每个下标i,以下条件均成立:

  • ans[i] OR (ans[i] + 1) == nums[i]

除此以外,你需要最小化结果数组里每一个ans[i]

如果没法找到符合条件ans[i],那么ans[i] = -1

质数指的是一个大于 1 的自然数,且它只有 1 和自己两个因数。

示例 1:

输入:nums = [2,3,5,7]

输出:[-1,1,4,3]

解释:

  • 对于i = 0,不存在ans[0]满足ans[0] OR (ans[0] + 1) = 2,所以ans[0] = -1
  • 对于i = 1,满足ans[1] OR (ans[1] + 1) = 3的最小ans[1]1,因为1 OR (1 + 1) = 3
  • 对于i = 2,满足ans[2] OR (ans[2] + 1) = 5的最小ans[2]4,因为4 OR (4 + 1) = 5
  • 对于i = 3,满足ans[3] OR (ans[3] + 1) = 7的最小ans[3]3,因为3 OR (3 + 1) = 7

示例 2:

输入:nums = [11,13,31]

输出:[9,12,15]

解释:

  • 对于i = 0,满足ans[0] OR (ans[0] + 1) = 11的最小ans[0]9,因为9 OR (9 + 1) = 11
  • 对于i = 1,满足ans[1] OR (ans[1] + 1) = 13的最小ans[1]12,因为12 OR (12 + 1) = 13
  • 对于i = 2,满足ans[2] OR (ans[2] + 1) = 31的最小ans[2]15,因为15 OR (15 + 1) = 31

提示:

  • 1 <= nums.length <= 100
  • 2 <= nums[i] <= 1000
  • nums[i]是一个质数。

解题方法:模拟

今天就每个数O ( 1 ) O(1)O(1)的话,明天的每日一题就没得做了。

对于一个数n nn,如何求得其对应的最小a n s ansans

使用一个变量从0 00试到n − 1 n-1n1就好了。

每个数都这样试试,也不用优化,今日的每日一题就这样结束了。

  • 时间复杂度O ( l e n ( n u m s ) × max ⁡ ( n u m s ) ) O(len(nums)\times\max(nums))O(len(nums)×max(nums))
  • 空间复杂度O ( 1 ) O(1)O(1),力扣返回值不计入算法空间复杂度

AC代码

C++
/* * @LastEditTime: 2026-01-20 22:52:17 */classSolution{private:intget(intn){for(inti=0;i<=n;i++){if((i|(i+1))==n){returni;}}return-1;}public:vector<int>minBitwiseArray(vector<int>&nums){vector<int>ans(nums.size());for(inti=0;i<nums.size();i++){ans[i]=get(nums[i]);}returnans;}};
Python
''' LastEditTime: 2026-01-20 22:55:49 '''fromtypingimportListclassSolution:defget(self,n:int)->int:foriinrange(n):if(i|(i+1))==n:# 不是(i or (i + 1))returnireturn-1defminBitwiseArray(self,nums:List[int])->List[int]:return[self.get(t)fortinnums]
Java
/* * @LastEditTime: 2026-01-20 23:04:56 */importjava.util.List;classSolution{privateintget(intn){for(inti=0;i<n;i++){if((i|(i+1))==n){returni;}}return-1;}publicint[]minBitwiseArray(List<Integer>nums){int[]ans=newint[nums.size()];// 是size不是lengthfor(inti=0;i<nums.size();i++){ans[i]=get(nums.get(i));}returnans;}}
Go
/* * @LastEditTime: 2026-01-20 22:58:16 */packagemainfuncminBitwiseArray(nums[]int)[]int{get:=func(nint)int{fori:=0;i<n;i++{if(i|(i+1))==n{returni}}return-1}ans:=make([]int,len(nums))fori,n:=rangenums{ans[i]=get(n)}returnans}
Rust
/* * @LastEditTime: 2026-01-20 23:07:14 */implSolution{fnget(n:i32)->i32{foriin0..n{if(i|(i+1))==n{returni;}}-1}pubfnmin_bitwise_array(nums:Vec<i32>)->Vec<i32>{nums.iter().map(|&num|Self::get(num)).collect()}}
Rust - 压缩版(bushi)
/* * @LastEditTime: 2026-01-20 23:09:46 */implSolution{pubfnmin_bitwise_array(nums:Vec<i32>)->Vec<i32>{nums.iter().map(|&n|{foriin0..n{if(i|(i+1))==n{returni;}}-1}).collect()}}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/27 21:32:05

Linux centos7 OOM Killer 配置详解

在 CentOS 7 中&#xff0c;OOM Killer&#xff08;Out-of-Memory Killer&#xff09; 是 Linux 内核在系统内存严重不足时&#xff0c;强制终止某些进程以释放内存的机制。 &#x1f50d; 查看 OOM Killer 日志 1. 系统日志查看 # 查看最近发生的 OOM 事件 sudo grep -i &q…

作者头像 李华
网站建设 2026/2/28 21:31:16

BluetoothDesktopHandlers.dll文件丢失找不到 免费下载方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/2/28 11:28:52

BootMenuUX.dll文件丢失找不到 免费下载方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/3/2 7:52:58

从挫折到成功:我的机器学习转型日记

第一章 测试思维遭遇算法黑箱&#xff08;第1-30天&#xff09; 技术冲突场景 黑盒困境&#xff1a;面对随机森林的预测结果&#xff0c;习惯性执行等价类划分却失效&#xff08;特征维度高达287个&#xff09; 验证危机- 传统断言方法在模型评估中全面崩盘&#xff1a; # 测…

作者头像 李华
网站建设 2026/3/3 0:33:55

传统调试vsAI辅助:解决排序异常效率提升300%

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 设计一个基准测试&#xff1a;1) 传统方法&#xff1a;给出一个有Comparison Method问题的Java代码片段&#xff0c;记录开发者平均发现和修复问题的时间 2) AI方法&#xff1a;使…

作者头像 李华
网站建设 2026/2/28 14:01:45

PyTorch镜像快速搭建指南,适合做课程实验环境

PyTorch镜像快速搭建指南&#xff0c;适合做课程实验环境 你是否在为深度学习课程的实验环境配置而头疼&#xff1f;手动安装PyTorch、CUDA驱动、Jupyter Notebook等组件不仅耗时&#xff0c;还容易因版本不兼容导致各种报错。本文将为你介绍一款开箱即用的PyTorch通用开发镜像…

作者头像 李华