2025/01/12 力扣每日一题

news/2025/1/12 13:27:14/文章来源:https://www.cnblogs.com/Eigh18n/p/18666899

2275. 按位与结果大于零的最长组合

对数组 nums 执行 按位与 相当于对数组 nums 中的所有整数执行 按位与

  • 例如,对 nums = [1, 5, 3] 来说,按位与等于 1 & 5 & 3 = 1
  • 同样,对 nums = [7] 而言,按位与等于 7

给你一个正整数数组 candidates 。计算 candidates 中的数字每种组合下 按位与 的结果。

返回按位与结果大于 0最长 组合的长度

示例 1:

输入:candidates = [16,17,71,62,12,24,14]
输出:4
解释:组合 [16,17,62,24] 的按位与结果是 16 & 17 & 62 & 24 = 16 > 0 。
组合长度是 4 。
可以证明不存在按位与结果大于 0 且长度大于 4 的组合。
注意,符合长度最大的组合可能不止一种。
例如,组合 [62,12,24,14] 的按位与结果是 62 & 12 & 24 & 14 = 8 > 0 。

示例 2:

输入:candidates = [8,8]
输出:2
解释:最长组合是 [8,8] ,按位与结果 8 & 8 = 8 > 0 。
组合长度是 2 ,所以返回 2 。

提示:

  • 1 <= candidates.length <= 105
  • 1 <= candidates[i] <= 107

我的解法

class Solution {
public:int largestCombination(vector<int>& candidates) {int ans = 0;for(int i = 0; i < 24; i++){int cnt = 0;for(auto& a : candidates){cnt += (a >> i) & 1;}ans = max(cnt, ans);}return ans;}
};

官方解法

class Solution {
public:int largestCombination(vector<int>& candidates) {// 计算从低到高第 k 个二进制位数值为 1 的元素个数auto maxlen = [&](int k) -> int {int res = 0;for (int num: candidates) {if (num & (1 << k)) {++res;}}return res;};int res = 0;for (int i = 0; i < 24; ++i) {// 遍历二进制位res = max(res, maxlen(i));}return res;}
};

大佬解法

#include <ranges>
// 一行法
class Solution {
public:int largestCombination(vector<int>& candidates) {return ranges::max(views::iota(0, 24) | views::transform([&](int i) {return ranges::count_if(candidates, [&](int x) {return x & (1 << i);});}));}
};

1. <ranges>

<ranges> 是C++20引入的一个新库,提供了对范围(ranges)的操作支持。它允许你以更简洁和声明式的方式处理容器和序列。

示例:

#include <iostream>
#include <vector>
#include <ranges>int main() {std::vector<int> numbers = {1, 2, 3, 4, 5};// 使用 ranges 过滤偶数auto even_numbers = numbers | std::views::filter([](int x) { return x % 2 == 0; });for (int x : even_numbers) {std::cout << x << " "; // 输出: 2 4}
}

说明

  • std::views::filter 是一个视图适配器,用于过滤满足条件的元素。
  • numbers | std::views::filter(...) 表示对 numbers 进行过滤操作。

2. ranges::max

ranges::max<ranges> 库中的一个算法,用于查找给定范围内的最大值。它类似于传统的 std::max,但可以直接作用于范围(range)而不需要显式的迭代器。

示例:

#include <iostream>
#include <vector>
#include <ranges>int main() {std::vector<int> numbers = {3, 1, 4, 1, 5, 9};// 使用 ranges::max 查找最大值int max_value = std::ranges::max(numbers);std::cout << "Max value: " << max_value << std::endl; // 输出: Max value: 9
}

说明

  • std::ranges::max 直接作用于容器,返回容器中的最大值。

3. views::iota

views::iota 是一个视图生成器,用于生成一个连续的整数序列。它的用法类似于Python中的 range 函数。在这个代码中,views::iota(0, 24) 生成了一个从0到23的整数序列(包含0,不包含24)。

示例:

#include <iostream>
#include <ranges>int main() {// 生成从 0 到 4 的整数序列auto numbers = std::views::iota(0, 5);for (int x : numbers) {std::cout << x << " "; // 输出: 0 1 2 3 4}
}

说明

  • std::views::iota(0, 5) 生成一个从 0 开始到 4 结束的序列(包含起始值,不包含结束值)。

4. views::transform

views::transform 是一个视图适配器,用于对范围内的每个元素应用一个转换函数。它类似于 std::transform,但以惰性求值的方式工作,只有在需要时才会进行计算。

在这个代码中,views::transformviews::iota(0, 24) 生成的每个整数 i 应用了一个 lambda 函数。这个 lambda 函数的作用是统计 candidates 中有多少个元素的第 i 位是1。

示例:

#include <iostream>
#include <vector>
#include <ranges>int main() {std::vector<int> numbers = {1, 2, 3, 4, 5};// 对每个元素乘以 2auto doubled = numbers | std::views::transform([](int x) { return x * 2; });for (int x : doubled) {std::cout << x << " "; // 输出: 2 4 6 8 10}
}

说明

  • std::views::transform 对每个元素应用 lambda 函数 [](int x) { return x * 2; },将其乘以 2。

5. ranges::count_if

ranges::count_if<ranges> 库中的一个算法,用于统计范围内满足特定条件的元素个数。它类似于 std::count_if,但可以直接作用于范围。

在这个代码中,ranges::count_if 统计 candidates 中满足 x & (1 << i) 条件的元素个数,即统计有多少个元素的第 i 位是1。

示例:

#include <iostream>
#include <vector>
#include <ranges>int main() {std::vector<int> numbers = {1, 2, 3, 4, 5};// 统计偶数个数int even_count = std::ranges::count_if(numbers, [](int x) { return x % 2 == 0; });std::cout << "Even count: " << even_count << std::endl; // 输出: Even count: 2
}

说明

  • std::ranges::count_if 统计 numbers 中满足 x % 2 == 0 的元素个数。

6. 整体逻辑

代码的整体逻辑是:

  • 生成一个从0到23的整数序列(因为整数的二进制表示最多有24位)。
  • 对每个整数 i,统计 candidates 中有多少个元素的第 i 位是1。
  • 最后,找出这些统计结果中的最大值,即 candidates 中所有元素的二进制表示中,某一位上1的最大出现次数。

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

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

相关文章

网站热门视频无法播放,如何解决?

针对您提到的网站热门视频无法播放的问题,我们可以从多个角度进行排查和解决。以下是一些建议,希望能帮助您快速找到问题所在并恢复正常播放功能。检查视频文件完整性:首先,请确认视频文件是否完整上传到了服务器。有时候由于网络波动或其他原因,可能导致文件传输过程中出…

服务器连接不上,如何排查和解决?

当您遇到服务器连接不上的问题时,首先需要明确具体的症状和环境。以下是详细的排查步骤和解决方案:确认网络连接:检查本地网络是否正常工作,尝试访问其他网站或服务,确保不是本地网络问题。 使用 ping 或 traceroute 命令测试与目标服务器的连通性。如果无法 ping 通,可能…

绑定域名后访问需输入账号密码,且静态资源跳转至缓存地址,如何处理?

当您绑定域名后访问网站时遇到需要输入账号密码以及静态资源跳转至缓存地址的问题,可能是由以下几种原因引起的。以下是详细的排查步骤和解决方案:确认身份验证设置:检查 Web 服务器(如 Apache、Nginx)的配置文件,确保没有启用不必要的身份验证机制。例如,Apache 的 .ht…

解决服务器卡顿及响应缓慢的问题

问题描述: 用户反映其服务器在迁移后出现了严重的卡顿现象,尤其是在执行某些特定操作(如批量打印快递单、查询会员列表)时,响应时间长达十几秒甚至二十多秒。这种情况严重影响了用户体验和工作效率。 解决方案:分析性能瓶颈:首先,使用性能分析工具(如top、htop、iosta…

解决FTP类问题:无法上传或下载文件

问题描述: 用户报告称其FTP账户虽然可以成功连接到服务器,但在尝试上传或下载文件时却失败了。这种情况严重影响了文件管理和更新工作,需要找出根本原因并解决。 解决方案:检查FTP权限设置:首先,确认FTP用户的权限是否足够。对于大多数FTP服务器,默认情况下用户具有读写…

如何解决网站伪静态设置后首页正常但其他页面404的问题

在配置伪静态规则后遇到了首页可以正常访问,但其他页面显示404错误的问题。这种情况通常与伪静态规则的配置、服务器环境或文件路径有关。以下是详细的排查步骤和解决方案:检查伪静态规则配置:确认伪静态规则是否正确配置。伪静态规则通常位于.htaccess(Apache服务器)或we…

9.水卡研究

学习资源:【【教程】手把手教你玩转IC卡-第1章-第1节-基础知识】https://www.bilibili.com/video/BV1QF411r7mw?vd_source=3e114458cfb3d0f9ecfb71a4c76c2465试验对象是本人大学水卡,因为是加密卡,需要嗅探,得要学校取水器,现在哩寒假在家,去嗅探,得开学了。 目前,就打…

ZIP伪加密解析

ZIP伪加密解析 1、zip组成 一个 ZIP 文件由三个部分组成:压缩源文件数据区+压缩源文件目录区+压缩源文件目录结束标志。 一个zip文件由这样三个部分组成_zip 文件结构_一只独孤的程序猿的博客-CSDN博客 2、实例压缩源文件数据区: 50 4B 03 04:这是头文件标记(0x04034b50) …

国内云服务器怎么选

前言 作为一名个人开发者,无论是搭建网站、编写小程序,还是运行脚本,我几乎离不开云服务器。回想从大学时期开始接触服务器,到如今进入职场,已累积了近十年的使用经验。从最初的“乞丐版”1核0.5G服务器,到如今的“土豪版”8核16G云服务器,再到云数据库、云Redis、云存储…

如何解决网站模板无法更新及后台操作异常的问题

您好,根据您的描述,您遇到了以下两个主要问题:网站模板无法更新,即使删除旧模板并上传新模板后,仍然显示旧模板。 登录网站后台后,部分系统板块无法点击,且栏目内容混乱。为了解决这些问题,请按照以下步骤进行排查和处理: 一、网站模板无法更新清除浏览器缓存浏览器缓…

如何安全有效地修改网站后台代码而不影响正常运行

问题描述: 用户希望能够安全有效地修改网站后台代码,但又担心会因为不当操作而导致网站无法正常运行。因此,他们寻求一种既能够实现定制化开发又能保证系统稳定性的方法。 回答: 当涉及到网站后台代码的修改时,确保安全性和稳定性是非常重要的。下面是一些实用的建议和最佳…

rust学习十六.3、并发-线程之间共享数据

线程之间共享数据,即go中部分人所憎恶的方式! 然而,这个方式并非没有其优点,否则操作系统也不提供这种实现方式。闲言少序,上正文! 一、概述 * 1.当我们大谈基于信道通信时,应该指的是应用级别。如果是操作系统,应该还是会有多种措施的,否则rust的源头在哪里来着。* 2…