leetcode_2103 环和杆

1. 题意

10个环。给定一个字符串每两个字符一组,第一个字符表示颜色(R,G,B),第二个字符表示在第几根杆上。求多少根杆上每个颜色都有。

环和杆

2. 题解

直接模拟记录即可,用位运算压缩。

cpp 复制代码
class Solution {
public:
    int countPoints(string rings) {
        function<int(char)> getIdx = [](char c)->int
        {
            if ( c == 'R')
                return 1;
            if ( c == 'G')
                return 2;
            if ( c == 'B' )
                return 4;
            return 0;
        };

        int sz = rings.size();

        int mem[10] = {0};
        for ( int i = 0;i < sz; i += 2) {
            mem[rings[i + 1] - '0'] |= getIdx(rings[i]);
        }


        return count(mem, mem + 10, 7);
    }

};
相关推荐
睡一觉就好了。6 分钟前
直接选择排序
数据结构·算法·排序算法
哈哈不让取名字11 分钟前
分布式日志系统实现
开发语言·c++·算法
芬加达13 分钟前
leetcode221 最大正方形
java·数据结构·算法
知无不研18 分钟前
实现一个整形栈
c语言·数据结构·c++·算法
夏鹏今天学习了吗20 分钟前
【LeetCode热题100(98/100)】子集
算法·leetcode·深度优先
DuHz21 分钟前
用于汽车应用的数字码调制(DCM)雷达白皮书精读
论文阅读·算法·自动驾驶·汽车·信息与通信·信号处理
李昊哲小课26 分钟前
机器学习核心概念与经典算法全解析
人工智能·算法·机器学习·scikit-learn
风筝在晴天搁浅1 小时前
hot100 437.路径总和Ⅲ
算法
lixzest1 小时前
软件工程师汇报能力提升工具包
职场和发展
sprintzer1 小时前
1.16-1.25力扣排序刷题
算法·leetcode·职场和发展