题解 | #比较版本号#

比较版本号

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语言编程#
全部评论

相关推荐

听说改名字就能收到offer哈:Radis写错了兄弟
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务