sicily 1029

本文介绍了一种使用 C++ 实现的大数相加算法。通过自定义数据结构存储大数,并实现加法运算符重载,可以处理超出标准整型变量范围的大数相加问题。适用于需要进行高精度计算的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大数相加

#include <iostream> #include <cstring> using namespace std; class Data { public: Data() { memset(a, 0, sizeof(a)); size = 0; } Data(int num) { setNum(num); } int a[100]; int size; Data operator =(Data tmp) { memcpy(a, tmp.a, sizeof(tmp.a)); size = tmp.size; return *this; } friend Data operator +(Data x, Data y) { Data tmp; int p = 0; //进位 int i = 0; tmp.size = x.size > y.size ? x.size : y.size; for(; i < tmp.size; i++) { tmp.a[i] = x.a[i] + y.a[i] + p; p = tmp.a[i] / 10; tmp.a[i] %= 10; } if(p != 0) { tmp.a[i] = p; (tmp.size)++; } return tmp; } void print() { for(int i = size - 1; i >= 0; i--) cout << a[i]; cout << endl; } void setNum(int num) { memset(a, 0, sizeof(a)); int i = 1; a[0] = num % 10; num /= 10; for(; num != 0; i++) { a[i] = num % 10; num /= 10; } size = i; } }; Data child[12]; int n, m; Data father; int main() { while(cin >> n >> m && !(n == 0 && m == 0)) { father.setNum(1); memset(child, 0, sizeof(child)); for(int i = 1; i <= m; i++) { for(int j = n + 1; j > 1; j--) child[j] = child[j - 1]; father = father + child[n + 1]; child[1] = father; } for(int i = 1; i <= n; i++) father = father + child[i]; father.print(); } return 0; }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值