leetcode:比较版本号

cpp 复制代码
class Solution {
public:
    stack<int> s1;
    
    
    stack<int> s2;
    
    long long getvalue(string s,int i,bool flag)
    {
        long long ret = 0;
        while (i < s.size() && s[i] == '0')
        {
            i++;
            if (flag)
                s1.push(i);
            else s2.push(i);
        }
        while (i<s.size()&& s[i] != '.')
        {
            ret = ret * 10 + s[i] - '0';
            i++;
            if (flag)
                s1.push(i);
            else s2.push(i);
        }
        return ret;
    }
    int compareVersion(string version1, string version2)
    {
        s1.push(-1);
        s2.push(-1);
        
        while (s1.top()+1 < version1.size() && s2.top()+1 < version2.size())
        {
            int ret = getvalue(version1, s1.top() + 1, 1) - getvalue(version2, s2.top() + 1, 0);
            if (ret > 0) return 1;
            else if (ret < 0) return -1;

        }
        int ret1 = 0;
        int ret2 = 0;
        while (s1.top() + 1 < version1.size())
        {
            ret1 += getvalue(version1, s1.top() + 1, 1);
        }
        while (s2.top() + 1 < version2.size())
        {
            ret2 += getvalue(version2, s2.top() + 1, 0);
        }
        if (ret1 > ret2)
            return 1;
        else if (ret1 < ret2)
            return -1;
        return 0;
        
    }
};

本人写的代码,不一定是最优解

相关推荐
搂鱼11451417 小时前
GJOI 10.7/10.8 题解
算法
Django强哥17 小时前
JSON Schema Draft-07 详细解析
javascript·算法·代码规范
AndrewHZ17 小时前
【图像处理基石】GIS图像处理入门:4个核心算法与Python实现(附完整代码)
图像处理·python·算法·计算机视觉·gis·cv·地理信息系统
杨小码不BUG18 小时前
蛇形舞动:矩阵填充的艺术与算法(洛谷P5731)
c++·算法·矩阵·csp-j/s·循环控制
MicroTech202518 小时前
微算法科技(NASDAQ:MLGO)开发延迟和隐私感知卷积神经网络分布式推理,助力可靠人工智能系统技术
人工智能·科技·算法
Boop_wu19 小时前
[数据结构] Map和Set
java·数据结构·算法
思考的笛卡尔20 小时前
密码学基础:RSA与AES算法的实现与对比
网络·算法·密码学
格林威1 天前
常规线扫描镜头有哪些类型?能做什么?
人工智能·深度学习·数码相机·算法·计算机视觉·视觉检测·工业镜头
007php0071 天前
某大厂跳动面试:计算机网络相关问题解析与总结
java·开发语言·学习·计算机网络·mysql·面试·职场和发展
程序员莫小特1 天前
老题新解|大整数加法
数据结构·c++·算法