本文主要是介绍C语言 | Leetcode C语言题解之第179题最大数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题目:
题解:
long cmp(int *x, int *y) {unsigned long sx = 10, sy = 10;while (sx <= *x) {sx *= 10;}while (sy <= *y) {sy *= 10;}return sx * (*y) + (*x) - sy * (*x) - (*y);
}char *largestNumber(int *nums, int numsSize) {qsort(nums, numsSize, sizeof(int), cmp);if (nums[0] == 0) {char *ret = malloc(sizeof(char) * 2);ret[0] = '0', ret[1] = '\0';return "0";}char *ret = malloc(sizeof(char) * 1000);char *p = ret;for (int i = 0; i < numsSize; i++) {sprintf(p, "%d", nums[i]);p += strlen(p);}return ret;
}
这篇关于C语言 | Leetcode C语言题解之第179题最大数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!