大整数乘法运算

cpp 复制代码
//
// Created by Administrator on 2026/3/28.
//
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAXSIZE 1000  // 大整数支持的最大位数

// 大整数结构体定义(与教材完全一致)
typedef struct {
    int digits[MAXSIZE]; // 低位到高位依次存储,digits[0] 是个位
    int length;          // 有效数字位数
    int sign;            // 符号:1 为正,-1 为负
} BigInt;

// ------------------- 1. 字符串转大整数 -------------------
BigInt StrToBigInt(const char *s) {
    BigInt num;
    num.length = 0;
    num.sign = 1;

    int len = strlen(s);
    int i = 0;
    if (s[0] == '-') {
        num.sign = -1;
        i = 1;
    }

    // 从后往前读,低位存到数组前面
    for (int j = len - 1; j >= i; j--) {
        num.digits[num.length++] = s[j] - '0';
    }

    return num;
}

// ------------------- 2. 打印大整数 -------------------
void PrintBigInt(BigInt num) {
    if (num.length == 0) {
        printf("0\n");
        return;
    }

    if (num.sign == -1) {
        printf("-");
    }

    // 从高位到低位打印
    for (int i = num.length - 1; i >= 0; i--) {
        printf("%d", num.digits[i]);
    }
    printf("\n");
}

// ------------------- 3. 大整数乘法(教材伪代码实现) -------------------
BigInt BigIntMultiply(BigInt a, BigInt b) {
    BigInt c;

    // 1. 处理结果为0的特殊情况
    if (a.length == 0 || b.length == 0) {
        c.sign = 1;
        c.length = 0;
        return c;
    }

    // 2. 判断结果的符号位
    if (a.sign == b.sign) {
        c.sign = 1;
    } else {
        c.sign = -1;
    }

    // 3. 确定结果的位数,并初始化
    c.length = a.length + b.length - 1;
    for (int i = 0; i < c.length; i++) {
        c.digits[i] = 0;
    }

    // 4. 按位相乘并累加
    for (int i = 0; i < a.length; i++) {
        for (int j = 0; j < b.length; j++) {
            c.digits[i + j] += a.digits[i] * b.digits[j];
        }
    }

    // 5. 从低位到高位处理进位
    int carry = 0;
    for (int i = 0; i < c.length; i++) {
        int temp = c.digits[i] + carry;
        c.digits[i] = temp % 10;
        carry = temp / 10;
    }

    // 6. 处理最高位进位
    if (carry > 0) {
        c.digits[c.length++] = carry;
    }

    // 7. 消除高位前导0
    while (c.length > 0 && c.digits[c.length - 1] == 0) {
        c.length--;
    }

    return c;
}

// ------------------- 测试主函数 -------------------
int main() {
    // 测试用例1:正数相乘 123 × 456 = 56088
    BigInt a = StrToBigInt("123");
    BigInt b = StrToBigInt("456");
    printf("a = "); PrintBigInt(a);
    printf("b = "); PrintBigInt(b);
    BigInt product = BigIntMultiply(a, b);
    printf("a × b = "); PrintBigInt(product);

    // 测试用例2:带负数相乘 -123 × 456 = -56088
    BigInt c = StrToBigInt("-123");
    printf("\nc = "); PrintBigInt(c);
    printf("b = "); PrintBigInt(b);
    BigInt product2 = BigIntMultiply(c, b);
    printf("c × b = "); PrintBigInt(product2);

    // 测试用例3:乘以0 999 × 0 = 0
    BigInt d = StrToBigInt("999");
    BigInt zero = StrToBigInt("0");
    printf("\nd = "); PrintBigInt(d);
    printf("zero = "); PrintBigInt(zero);
    BigInt product3 = BigIntMultiply(d, zero);
    printf("d × zero = "); PrintBigInt(product3);

    return 0;
}

两数相乘,其结果的位数至少是两数位数之和-1.

乘法思想:个位乘个位算个位,个位累加。

个位乘百位算百位,百位乘个位算百位,十位乘十位算百位。百位累加。

相关推荐
白羊by3 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖4 小时前
最大最小值降采样算法的优化
c++·算法
glimix4 小时前
Word-Pop:使用C语言开发打单词游戏
c语言·游戏
white-persist6 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
FL16238631297 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
独小乐7 小时前
019.ADC转换和子中断|千篇笔记实现嵌入式全栈/裸机篇
linux·c语言·驱动开发·笔记·嵌入式硬件·mcu·arm
baizhigangqw7 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
C雨后彩虹8 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_25019 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-1301239 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法