• C语言力扣第43题之字符串相乘。优化竖式


    给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。

    注意:不能使用任何内置的 BigInteger 库或直接将输入转换为整数。

    示例 1:

    输入: num1 = "2", num2 = "3"
    输出: "6"

    示例 2:

    输入: num1 = "123", num2 = "456"
    输出: "56088"

    提示:

        1 <= num1.length, num2.length <= 200
        num1 和 num2 只能由数字组成。
        num1 和 num2 都不包含任何前导零,除了数字0本身。

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/multiply-strings
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    使用数组代替字符串存储结果,则可以减少对字符串的操作。

    令 m 和 n 分别表示 num1​ 和 num2 的长度,并且它们均不为 0,则 num1 和 num2 的乘积的长度为 m+n−1或 m+n。简单证明如下:

    ——如果 num1​ 和 num2​ 都取最小值,则 num1=10^{m-1},num2=10^{n-1},num1×num2=10^{m+n-2},乘积的长度为 m+n−1;

    ——如果 num1​ 和 num2 都取最大值,则 num1=10^m-1,num2=10^n-1,num1×num2=10^{m+n}-10^m-10^n+1,乘积显然小于 10^{m+n}且大于 10^{m+n-1},因此乘积的长度为 m+n。

    由于 num1​ 和 num2​ 的乘积的最大长度为 m+n,因此创建长度为 m+n 的数组 ansArr用于存储乘积。对于任意 0≤i
    最后,将数组 ansArr 转成字符串,如果最高位是 0 则舍弃最高位。

    1. #define _CRT_SECURE_NO_WARNINGS
    2. #include
    3. #include
    4. char * multiply(char * num1, char * num2)
    5. {
    6. int m = strlen(num1), n = strlen(num2);
    7. char* ans = malloc(sizeof(char) * (m + n + 3));
    8. memset(ans, 0, sizeof(char) * (m + n + 3));
    9. int* ansArr = malloc(sizeof(int) * (m + n + 3));
    10. memset(ansArr, 0, sizeof(int) * (m + n + 3));
    11. int i = 0;
    12. int ansLen = 0;
    13. int index = 0;
    14. if ((m == 1 && num1[0] == '0') || (n == 1 && num2[0] == '0'))
    15. {
    16. ans[0] = '0', ans[1] = 0;
    17. return ans;
    18. }
    19. for ( i = m - 1; i >= 0; i--) {
    20. int x = num1[i] - '0';
    21. for (int j = n - 1; j >= 0; j--) {
    22. int y = num2[j] - '0';
    23. ansArr[i + j + 1] += x * y;
    24. }
    25. }
    26. for ( i = m + n - 1; i > 0; i--) {
    27. ansArr[i - 1] += ansArr[i] / 10;
    28. ansArr[i] %= 10;
    29. }
    30. index = ansArr[0] == 0 ? 1 : 0;
    31. ansLen = 0;
    32. while (index < m + n) {
    33. ans[ansLen++] = ansArr[index];
    34. index++;
    35. }
    36. for ( i = 0; i < ansLen; i++) ans[i] += '0';
    37. return ans;
    38. }
    39. int main()
    40. {
    41. char num1[] = "123";
    42. char num2[] = "456";
    43. char num3[1000] = "";
    44. strcpy(num3,multiply(num1, num2));
    45. printf("%s", num3);
    46. return 0;
    47. }

  • 相关阅读:
    基于QT和C++实现的停车场管理系统
    SIMD理解和学习入门资源
    聚乙二醇修饰单分散/功能化聚乙烯胺/热敏性PNVIBA/温敏性PNIPAAm接枝聚苯乙烯微球
    【测试】1. 概念 + 基础篇
    阿里云国际版Windows服务器磁盘空间不足该怎么办?
    Azure 开发者新闻快讯丨开发者6月大事记一览
    Python21天学习挑战赛Day(8)·多进程
    WIFI码挪车码创建生成CPS聚合流量主小程序开发
    Redis夺命十二问,你能扛到第几问?
    wpf devexpress Property Gird管理集合属性
  • 原文地址:https://blog.csdn.net/qq_52505851/article/details/126001068