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

};
相关推荐
充值修改昵称几秒前
数据结构基础:B+树如何优化数据库性能
数据结构·b树·python·算法
Cinema KI几秒前
一键定位,哈希桶的极速魔法
数据结构·c++·算法·哈希算法
曾几何时`6 分钟前
二分查找(九)2300. 咒语和药水的成功对数
数据结构·算法
We་ct24 分钟前
LeetCode 12. 整数转罗马数字:从逐位实现到规则复用优化
前端·算法·leetcode·typescript
绿算技术26 分钟前
重塑智算存储范式:绿算技术NVMe-oF芯片解决方案全景剖析
人工智能·算法·gpu算力
sin_hielo39 分钟前
leetcode 3510
数据结构·算法·leetcode
努力学算法的蒟蒻1 小时前
day64(1.23)——leetcode面试经典150
面试·职场和发展
Anastasiozzzz1 小时前
力扣hot100 20.有效的括号 解析
java·算法·面试·力扣
CrazyClaz1 小时前
负载均衡算法
算法·负载均衡
嵌入式小能手1 小时前
飞凌嵌入式ElfBoard-系统信息与资源之休眠
c语言·开发语言·算法