题解 | #比较版本号#

比较版本号

https://www.nowcoder.com/practice/2b317e02f14247a49ffdbdba315459e7

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 比较版本号
 * @param version1 string字符串 
 * @param version2 string字符串 
 * @return int整型
 */
int compare(char* version1, char* version2 ) {
    // write code here
    int i=0,j=0,t = 0,len1=0,len2=0;
    int len=0;

    len1 = strlen(version1);
    len2 = strlen(version2);
    int *num1 = (int *)malloc(sizeof(int) * len1);
    int *num2 = (int *)malloc(sizeof(int) * len2);
  	/*申请的空间赋值0*/
    memset(num1,0,len1);
    memset(num2,0,len2);

    //获取每个‘.’之前的数字;
    while(version1[i] != '\0')
    {
        if(version1[i] == '.')
        {
            i++;
            j++;
            continue;
        }
        num1[j] = num1[j]*10 + (version1[i++] - '0');
    }
    j++;
    i=0;
    while(version2[i] != '\0')
    {
        if(version2[i] == '.')
        {
            i++;
            t++;
            continue;
        }
        num2[t] = num2[t]*10 + (version2[i++] - '0');
    }
    t++;
    len = j>t?j:t;	//取长度最长比较;
    
    for(i=0;i<len;i++)
    {
        if(num1[i] > num2[i])
            return 1;
        if(num1[i] < num2[i])
            return -1;
    }
    return 0;   
}

#c语言编程#
全部评论

相关推荐

10-13 22:56
门头沟学院 C++
rt,鼠鼠的浪潮网签明天过期,鼠鼠是山东人,好像自己也能接受。之前的面试大厂基本挂干净了,剩下小米二面后在泡,问了下面试官没有挂,但要泡。还有海信似乎也通过了,不过在深圳,鼠鼠也不是很想去。其它还有一些公司应该陆陆续续还有一些面试,现在有些纠结是直接签了还是再等再面呢?大佬们能不能给鼠鼠提一些意见,万分感谢!!!
牛客78696106...:浪潮可不是开摆,当初我还是开发的时候我组长跟我说他们组有段时间天天1,2点走,早上5点就来,全组肝出来心肌炎,浪潮挣钱省立花可不是说说,当然也看部门,但是浪潮普遍就那dio样,而且你算下时薪就知道不高,没事也是9点半走,不然算你旷工
投递小米集团等公司10个岗位
点赞 评论 收藏
分享
牛客96763241...:杭电✌️也是打完招呼,没人回吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务