3461. 判断操作后字符串中的数字是否相等 I

3461. 判断操作后字符串中的数字是否相等 I


题目链接:3461. 判断操作后字符串中的数字是否相等 I

代码如下:

cpp 复制代码
class Solution {
public:
    bool hasSameDigits(string s) {
        int n = s.size();

        // 预处理 2 和 5 的幂次
        int P2[n + 1], P5[n + 1];
        P2[0] = P5[0] = 1;
        for (int i = 1; i <= n; i++) P2[i] = P2[i - 1] * 2 % 10, P5[i] = P5[i - 1] * 5 % 10;

        // 扩展欧几里得算法
        auto exgcd = [&](this auto &&self, int a, int b, int &x, int &y) -> void {
            if (b == 0) {
                x = 1; y = 0;
                return;
            }
            self(b, a % b, y, x);
            y -= a / b * x;
        };

        // 求 s[l] 到 s[r] 合并起来的结果
        auto calc = [&](int l, int r) {
            int n = r - l;
            // c:抛掉因数 2 和 5 后,组合数 mod 10 的结果
            // two:组合数里因数 2 有几个
            // five:组合数里因数 5 有几个
            int c = 1, two = 0, five = 0, sm = 0;
            for (int i = l, j = 0; ; i++, j++) {
                // 按公式求和
                sm = (sm + (s[i] - '0') * P2[two] * P5[five] * c) % 10;
                if (i == r) break;
                // 组合数递推式,先乘 (n - m)
                int t = n - j;
                while (t % 2 == 0) two++, t /= 2;
                while (t % 5 == 0) five++, t /= 5;
                c = c * t % 10;
                // 组合数递推式,再除 (m + 1)
                t = j + 1;
                while (t % 2 == 0) two--, t /= 2;
                while (t % 5 == 0) five--, t /= 5;
                // 扩展欧几里得算法求逆元
                int x, y;
                exgcd(t, 10, x, y);
                c = c * (x % 10 + 10) % 10;
            }
            return sm;
        };

        return calc(0, n - 2) == calc(1, n - 1);
    }
};
相关推荐
ha204289419413 分钟前
Linux操作系统学习记录之---TcpSocket
linux·网络·c++·学习
AI视觉网奇1 小时前
ue5 插件 WebSocket
c++·ue5
左直拳2 小时前
将c++程序部署到docker
开发语言·c++·docker
恒者走天下2 小时前
AI智能体通讯项目(底层AI通讯协议实现)
c++
英雄各有见2 小时前
Chapter 5.1.1: 编写你的第一个GPU kernel——Cuda Basics
c++·gpu·cuda·hpc
梵尔纳多2 小时前
OpenGL着色器语言(GLSL)
c++·opengl·着色器
net3m332 小时前
单片机屏幕多级菜单系统之当前屏幕号+屏幕菜单当前深度 机制
c语言·c++·算法
mmz12072 小时前
二分查找(c++)
开发语言·c++·算法
陌路203 小时前
C++30 STL容器 -deque双端队列
开发语言·c++
AI视觉网奇3 小时前
ue 自己制作插件 c++
c++·ue5