题解 | #比较版本号#
比较版本号
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语言编程#