首页 > 其他分享 >2025/01/12 力扣每日一题

2025/01/12 力扣每日一题

时间:2025-01-12 13:33:26浏览次数:1  
标签:std 12 views int 力扣 2025 candidates numbers include

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};

    // 对每个元素乘以 2
    auto 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的最大出现次数。

标签:std,12,views,int,力扣,2025,candidates,numbers,include
From: https://www.cnblogs.com/Eigh18n/p/18666899

相关文章

  • 2025毕设python在线美食点评系统程序+论文
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容一、选题背景关于美食点评系统的研究,现有研究主要集中在大型综合平台的整体运营和功能优化方面,如大众点评、美团等平台的宏观运营模式、营销策略等......
  • 2025/01/12 cpp学习日记
    学到的新知识std::vector::resizestd::vector::resize是C++标准库中std::vector类的一个成员函数,用于调整向量的大小。它可以增加或减少向量中元素的数量,并根据需要初始化新元素或删除多余的元素。函数原型std::vector::resize有两个重载版本:调整大小并默认初始化新......
  • 1.12 CW 模拟赛 赛时记录
    看题不是哥们怎么感觉一堆原题但是都不会做没复习最悲惨的一次策略肯定还是暴力,没有什么看上去简单的题\(\rm{T1}\)思路侥幸心理找了一下没有啊,必须自己想合法串显然就是满足匹配的串考虑这种经典问题的常见转化:令(为\(1\),)为\(-1\),合法括号串仅当其任......
  • 【JavaWeb学习Day12】
    MyBatis简介:Mybatis是一款优秀的持久层框架,用于简化JDBC的开发。Mybatis本是Apache的一个开源项目ibatis,2010年这个项目由apache迁移到了googlecode,并且改名为Mybatis。2013年11月迁移到github官网:https://mybatis.org/mybatis-3/zh/index.html01.入门程序:使用Mybatis查......
  • 日常训练2025-1-12
    日常训练2025-1-12P2679[NOIP2015提高组]子串普及+/提高https://www.luogu.com.cn/problem/P2679思路https://www.luogu.com.cn/article/k0zkdin9评述做DP时可以把能想到的有用的状态都定义出来,后序在把不需要的,或者可以根据其他状态推出来的状态删除,逐渐优化。......
  • Shelly聊AI:年度展望:2025年AI与社会发展关键事件的深度思考(每年一篇,十年为期)
    大家好,我是Shelly,一个专注于输出AI工具和科技前沿内容的AI应用教练,体验过300+款以上的AI应用工具。关注科技及大模型领域对社会的影响10年+。关注我一起驾驭AI工具,拥抱AI时代的到来。人工智能&AIGC术语100条Shelly聊AI-重磅发布在人类浩瀚的历史中,人工智能犹如一颗璀璨夺目......
  • 【练习】力扣 热题100 最大子数组和
    题目给你一个整数数组nums,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。子数组是数组中的一个连续部分。示例1:输入:nums=[-2,1,-3,4,-1,2,1,-5,4]输出:6解释:连续子数组[4,-1,2,1]的和最大,为6。示例2:输入:nums=[1]输出:......
  • Mac电脑如何安装Xmind 2025 中文思维导图软件?
    Mac电脑如何安装Xmind2025中文思维导图软件?介绍Xmind,是一款出色的思维导图和头脑风暴软件,拥有美观的智能配色方案,便于你轻松理清思路捕捉创意。丰富的导图模板及多种创意整合工具,可助力导图迸发更多活力。还拥有强大演说模式,及提供Markdown、SVG、PNG、PDF、Office等......
  • Mac电脑如何安装Xmind 2025 中文思维导图软件?
    Mac电脑如何安装Xmind2025中文思维导图软件?介绍Xmind,是一款出色的思维导图和头脑风暴软件,拥有美观的智能配色方案,便于你轻松理清思路捕捉创意。丰富的导图模板及多种创意整合工具,可助力导图迸发更多活力。还拥有强大演说模式,及提供Markdown、SVG、PNG、PDF、Office等......
  • SpringBoot面试题(2025)
    什么是SpringBoot?多年来,随着新功能的增加,spring变得越来越复杂。只需访问https://spring.io/projects页面,我们就会看到可以在我们的应用程序中使用的所有Spring项目的不同功能。如果必须启动一个新的Spring项目,我们必须添加构建路径或添加Maven依赖关系,配置应......