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
相关推荐
naruto_lnq1 分钟前
C++中的桥接模式
开发语言·c++·算法
苦藤新鸡1 分钟前
50.腐烂的橘子
数据结构·算法
想进个大厂7 分钟前
代码随想录day32 动态规划01
算法·动态规划
j4455661119 分钟前
C++中的职责链模式高级应用
开发语言·c++·算法
uesowys23 分钟前
Apache Spark算法开发指导-Decision tree classifier
算法·决策树·spark
池央31 分钟前
贪心算法-最大数
算法·贪心算法
iAkuya37 分钟前
(leetcode)力扣100 57电话号码的字母组合(回溯)
算法·leetcode·深度优先
m0_736919101 小时前
模板元编程性能分析
开发语言·c++·算法
pen-ai1 小时前
【YOLO系列】 YOLOv1 目标检测算法原理详解
算法·yolo·目标检测
2301_765703141 小时前
C++中的职责链模式实战
开发语言·c++·算法