LeetCode 2044.统计按位或能得到最大值的子集数目

给你一个整数数组 nums ,请你找出 nums 子集 按位或 可能得到的 最大值 ,并返回按位或能得到最大值的 不同非空子集的数目 。

如果数组 a 可以由数组 b 删除一些元素(或不删除)得到,则认为数组 a 是数组 b 的一个 子集 。如果选中的元素下标位置不一样,则认为两个子集 不同 。

对数组 a 执行 按位或 ,结果等于 a[0] OR a[1] OR … OR a[a.length - 1](下标从 0 开始)。

示例 1:

输入:nums = [3,1]
输出:2
解释:子集按位或能得到的最大值是 3 。有 2 个子集按位或可以得到 3 :

  • [3]
  • [3,1]
    示例 2:

输入:nums = [2,2,2]
输出:7
解释:[2,2,2] 的所有非空子集的按位或都可以得到 2 。总共有 23 - 1 = 7 个子集。
示例 3:

输入:nums = [3,2,1,5]
输出:6
解释:子集按位或可能的最大值是 7 。有 6 个子集按位或可以得到 7 :

  • [3,5]
  • [3,1,5]
  • [3,2,5]
  • [3,2,1,5]
  • [2,5]
  • [2,1,5]

提示:

1 <= nums.length <= 16
1 <= nums[i] <= 105

法一:通过位运算求出所有子集,然后计算每个子集按位或的结果:

class Solution {
public:int countMaxOrSubsets(vector<int>& nums) {int maxOrRes = 0;int maxOrResNum = 0;int maxSubsetNum = pow(2, nums.size());for (int i = 0; i < maxSubsetNum; ++i){int orRes = 0;for (int j = 0; j < nums.size(); ++j){if ((1 << j) & i){orRes |= nums[j];}}if (orRes > maxOrRes){maxOrRes = orRes;maxOrResNum = 1;}else if (orRes == maxOrRes){++maxOrResNum;}}return maxOrResNum;}
};

如果nums中有n个元素,此算法时间复杂度为O(n2 n ^n n),空间复杂度为O(1)。

法二:同法一,但通过递归来找所有子集:

class Solution {
public:int countMaxOrSubsets(vector<int>& nums) {int ans = 0;findSubsets(nums, 0, ans, 0);return ans;}private:int curOrRes = 0;int curMaxSubsetOrRes = 0;void findSubsets(const vector<int> &nums, int index, int &ans,int curSubsetOrRes){if (index == nums.size()){if (curSubsetOrRes > curMaxSubsetOrRes){curMaxSubsetOrRes = curSubsetOrRes;ans = 1;}else if (curSubsetOrRes == curMaxSubsetOrRes){++ans;}return;}findSubsets(nums, index + 1, ans, curSubsetOrRes);findSubsets(nums, index + 1, ans, curSubsetOrRes | nums[index]);}
};

如果nums中有n个元素,此算法时间复杂度为O(n2 n ^n n),空间复杂度为O(n)。

法三:类似法一,我们用数字中值为1的位来表示nums中被选中到该数字表示的子集中的数在nums中的下标,但这次我们用动态规划来实现:

class Solution {
public:int countMaxOrSubsets(vector<int>& nums) {int subsetNum = 1 << nums.size();vector<int> dp(subsetNum);// 处理子集中只有1个数字时的按位或,此时按位或为该数字本身for (int i = 0; i < nums.size(); ++i){dp[1 << i] = nums[i];}int ans = 0;int max = 0;for (int i = 1; i < subsetNum; ++i){int lowbit = i & -i;// dp[i - lowbit]就是去除lowbit后的数字表示的子集// dp[lowbit]是lowbit表示的子集,显然lowbit只有一位// 结果就是i - lowbit表示的子集与lowbit表示的子集的与dp[i] = dp[i - lowbit] | dp[lowbit];if (dp[i] > max){max = dp[i];ans = 1;}else if (dp[i] == max){++ans;}}return ans;}
};

如果nums中有n个元素,此算法时间复杂度为O(2 n ^n n),空间复杂度为O(2 n ^n n)。相比法一,是用空间换时间。

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

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

相关文章

vue如何优化首页加载速度

优化 Vue.js 应用的首页加载速度是提升用户体验的关键之一。以下是一些优化 Vue.js 应用首页加载速度的常见方法&#xff1a; 代码分割&#xff08;Code Splitting&#xff09;&#xff1a; 将应用代码拆分成多个小块&#xff0c;并按需加载。可以使用 Vue Router 的懒加载功能…

ElasticSearch 与java的结合使用(一)

引入依赖 <dependency><groupId>org.elasticsearch</groupId><artifactId>elasticsearch</artifactId><version>7.15.2</version><exclusions><!-- 排除自带的logback依赖 --><exclusion><groupId>org.apac…

docker的安装与使用

1.打开启动或关闭windows功能 2.勾选Hyper-V、适用于Linux的Windows子系统&#xff0c;虚拟机平台三项 若没有Hyper-V&#xff0c;以管理员身份执行以下文件 创建Hyper-V Installer.cmd&#xff0c;然后写入 pushd "%~dp0" dir /b %SystemRoot%\servicing\Package…

51单片机基础篇系列-51单片机基础开发流程和基本I/O口

&#x1f308;个人主页: 会编程的果子君 &#x1f4ab;个人格言:“成为自己未来的主人~” 51开发平台的组成 单片机应用系统&#xff08;也叫目标系统&#xff09; 硬件&#xff1a; 用户可以自己设计制作&#xff0c;也可以采用现成的开发板快捷搭建 软件&#xff1a; …

扁平数据转树形结构,让数据管理更清晰

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

LangChain原理深度解析:构建高效语言模型应用的关键框架

LangChain原理介绍 摘要&#xff1a; 本文将详细介绍LangChain的基本原理&#xff0c;包括其设计思路、核心组件、工作流程以及在语言模型应用开发中的应用。通过通俗易懂的语言&#xff0c;本文旨在让读者对LangChain有一个全面的了解。 关键词&#xff1a; LangChain&#…

1.初学docker

这是在centos7上的基本操作用法。 一、基本操作 # 安装yum源 yum install -y yum-utils # 配置yum源 yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo # 安装docker yum install -y docker-ce-cli containerd.io docker-buildx-plu…

数学计算器

1 问题 该代码提供了一个简单的数学计算器&#xff0c;可以让用户输入一个数学表达式并计算结果。这个计算器可以用于执行各种基本数学运算&#xff0c;如加法、减法、乘法、除法、幂运算等&#xff0c;也可以处理更复杂的表达式&#xff0c;如三角函数、对数、指数等。 2 方法…

C语言——函数指针——函数指针数组 (详解)

函数指针数组 函数指针数组的作用 函数指针数组是一个数组&#xff0c;其中的每个元素都是一个函数指针。函数指针是指向函数的指针变量&#xff0c;可以用来调用相应的函数。函数指针数组的作用是可以根据需要动态地选择并调用不同的函数。 函数指针数组的使用场景有很多&…

MIT 6.858 计算机系统安全讲义 2014 秋季(四)

译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 污点跟踪 注意&#xff1a; 这些讲座笔记是从 2014 年 6.858 课程网站上发布的笔记上稍作修改的。 安卓安全策略 这篇论文试图解决什么问题&#xff1f; 应用程序可以外泄用户的私人数据并发送到某个服务器。 高层次…

Linux bzip2命令教程:文件压缩与解压缩实战(附案例详解和注意事项)

Linux bzip2命令介绍 bzip2是一个基于命令行的文件压缩器&#xff0c;它使用Burrows-Wheeler块排序文本压缩算法和哈夫曼编码来进行压缩。它的主要功能是压缩和解压缩文件&#xff0c;将多个文件绑定成一个单一的文件&#xff0c;这样可以减少原始文件所占用的存储空间。 Lin…

微服务day06-Docker

Docker 大型项目组件较多&#xff0c;运行环境也较为复杂&#xff0c;部署时会碰到一些问题&#xff1a; 依赖关系复杂&#xff0c;容易出现兼容性问题 开发、测试、生产环境有差异 1.什么是Docker? 大型项目组件很多&#xff0c;运行环境复杂&#xff0c;部署时会遇到各种…

WatchBird: 新一代纯PHP防火墙

WatchBird: 新一代纯PHP防火墙 工具安装 广大研究人员可以使用下列命令直接将项目源码克隆至本地 git clone https://github.com/leohearts/awd-watchbird.git工具部署 1.进入下载好的文件夹目录 2.编译waf.c生成.so文件,参考命令:gcc waf.c -shared -fPIC -o waf.so 3.将w…

大数(long long 也存不下)求余数

现在有一个数n为&#xff1a;12345678901234567890123456789012345678901234567890&#xff0c;要你求 n / 2023 和 n % 2023 的数值 模拟长除法 平时我们在进行除法时&#xff0c;用的是长除法&#xff0c;我们可以用代码来模拟这种思路 #include<iostream> #include<…

Beans模块之工厂模块BeanFactory

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

SDK集群模式数据库中,ETCD起什么作用?

在云计算中&#xff0c;数据库使用 ETCD 和 SDK 集群模式可以提高数据库的可用性、可扩展性和灵活性。具体来说&#xff0c;可以使用 ETCD 来存储和管理数据库的配置信息、状态信息、元数据等&#xff0c;然后使用 SDK 集群模式来开发和部署数据库应用程序。 在使用 ETCD 和 SD…

Linux 之九:CentOS 上 Tomcat 安装、SpringBoot 项目打包和部署

安装 Tomcat 下载 a. 方式一&#xff1a;可以在windows 真机上下载后&#xff0c;再上传到服务器 b. 方式二&#xff1a;可以在服务器端使用 wget 下载命令来下载 登录官网https://tomcat.apache.org/download-90.cgi&#xff0c;选择 linux 版本 右键&#xff0c;获取下载链接…

服务器-->网站制作-->接口开发,一篇文章一条龙服务(2)

作者&#xff1a;q: 1416279170v: lyj_txd前述&#xff1a;本人非专业&#xff0c;兴趣爱好自学自研&#xff0c;很多没有说清楚的地方见谅&#xff0c;欢迎一起讨论的小伙伴~ 上期回顾&#xff0c;了解 服务器&#xff0c;网站制作&#xff0c;接口开发之见的关系&#xff0c…

vue中实现3d词云效果(已封装组件)

<!--* Description: 词云组件 页面* Date: 2024/3/10 23:39 --> <template><div:style"{display: flex,justifyContent: center,border: 1px solid red,}"><svg:width"width":height"height"mousemove"listener($even…

flask 支持跨域访问 非常简单的方式 flask_cors

安装 pip install -U flask-cors from flask import Flask from flask_cors import CORSapp Flask(__name__) CORS(app)app.route("/") def helloWorld():return "Hello, cross-origin-world!"参考 https://www.cnblogs.com/anxminise/p/9814326.html …