LeetCode 2103.环和杆

原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

C++代码

常规

cpp 复制代码
class Solution {
public:
    int countPoints(string rings) {
        int count = 0;
        set<string>se[10];
        for(int i=1,j=0;i<rings.length();i+=2,j+=2){
            se[rings[i]-'0'].insert(to_string(rings[j]));
        }

        for(int i=0;i<10;i++){
            if(se[i].size()==3) count++;  
        }
        
        return count;
    }
};

Python代码

位运算

python 复制代码
class Solution:
    def countPoints(self, rings: str) -> int:
        n,count = len(rings),0
        binary_map = [0]*17  # R - B = 17
        for i in range(0,n,2):
            binary_map[ord(rings[i]) - ord('B')] |= 1 << (int(rings[i+1]) - int('0'))  
        for i in range(10):
            tmp = 0
            for ch in ['R','G','B']:
                tmp += (binary_map[ord(ch)-ord('B')] >> i) & 1  #第i根杆 上是否有ch颜色的圈
            if tmp == 3:
                count += 1
        return count
相关推荐
TracyCoder1237 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
u0109272718 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_941837268 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
六义义10 小时前
java基础十二
java·数据结构·算法
四维碎片10 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs10 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E10 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766811 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王11 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展
Swift社区11 小时前
LeetCode 385 迷你语法分析器
算法·leetcode·职场和发展