鱼C论坛

 找回密码
 立即注册
查看: 1895|回复: 4

[已解决]高精度乘法出问题

[复制链接]
发表于 2022-6-24 21:24:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 柿子饼同学 于 2022-6-24 21:30 编辑

题目 : https://www.luogu.com.cn/problem/P1303
  1. #include <bits/stdc++.h>
  2. using namespace std;

  3. int l, la, lb;
  4. string f, s;
  5. char op;

  6. short a[2002], b[2002], ans[4004];

  7. void read(){ //把读入字符串转倒序数组
  8.     memset(a, 0, sizeof(a)); memset(b, 0, sizeof(b)); memset(ans, 0, sizeof(ans));
  9.     la = f.size(); lb = s.size(); l = la > lb ? la : lb;
  10.     for(int i = la - 1; i >= 0; i--) a[la-i-1] = f[i] - '0';
  11.     for(int i = lb - 1; i >= 0; i--) b[lb-i-1] = s[i] - '0';
  12. }

  13. void print(short x[]){ //打印答案
  14.     int num = 4004;
  15.     while(!ans[num] && num > 0) --num;
  16.     for(int i = num; i >= 0; i--) cout << ans[i];
  17.     cout << endl;
  18. }

  19. void mul(short x[], short y[]){
  20.     // 这里直接计算结果中的从低到高第 i 位,且一并处理了进位
  21.     // 第 i 次循环为 c[i] 加上了所有满足 p + q = i 的 a[p] 与 b[q] 的乘积之和
  22.     for(int i = 0; i < l; i++){
  23.         for(int j = 0; j <= i; j++){
  24.             ans[i] += x[j] * y[i-j];
  25.         }
  26.         if(ans[i] >= 10){
  27.             ans[i+1] += ans[i] / 10;
  28.             ans[i] %= 10;
  29.         }
  30.     }
  31. }

  32. int main(){
  33.     ios::sync_with_stdio(0);
  34.     cin >> f >> s;
  35.     read();
  36.     mul(a, b);
  37.     print(ans);
  38.     return 0;
  39. }
复制代码

我代码一直答案错 , 不知道怎么回事
求帮助 , 看看哪里错了
最佳答案
2022-6-25 07:12:47
本帖最后由 jhq999 于 2022-6-25 09:30 编辑

看看
  1. #include <bits/stdc++.h>
  2. using namespace std;

  3. int l, la, lb;
  4. string f, s;
  5. char op;

  6. short a[2002], b[2002], ans[4004];//////////////感觉这里变量类型用char就行了,9*9<255

  7. void read(){ //把读入字符串转倒序数组
  8.     memset(a, 0, sizeof(a)); memset(b, 0, sizeof(b)); memset(ans, 0, sizeof(ans));
  9.     la = f.size(); lb = s.size(); l = la + lb;
  10.     for(int i = la - 1; i >= 0; i--) a[la-i-1] = f[i] - '0';
  11.     for(int i = lb - 1; i >= 0; i--) b[lb-i-1] = s[i] - '0';
  12. }

  13. void print(short x[]){ //打印答案
  14.     int num = 4004;
  15.     while(!ans[num] && num > 0) --num;
  16.     for(int i = num; i >= 0; i--) cout << ans[i];
  17.     cout << endl;
  18. }

  19. void mul(short x[], short y[]){
  20.     // 这里直接计算结果中的从低到高第 i 位,且一并处理了进位
  21.     // 第 i 次循环为 c[i] 加上了所有满足 p + q = i 的 a[p] 与 b[q] 的乘积之和
  22.     for(int i = 0; i < la; i++){/////////////////////////////////
  23.         for(int j = 0; j <lb; j++){////////////////////////////

  24.             ans[i+j] += x[i] * y[j];
  25.         }
  26.         for(int k=0;k<lb;k+=1)///////////////////////////////////////
  27.         {
  28.             if(ans[i+k]>9)
  29.             {
  30.                 ans[i+k+1]+=ans[i+k]/10;
  31.                 ans[i+k]=ans[i+k]%10;
  32.             }
  33.         }
  34.     }
  35. }

  36. int main(){
  37.     ios::sync_with_stdio(0);
  38.     cin >> f >> s;
  39.     read();
  40.     mul(a, b);
  41.     print(ans);
  42.     return 0;
  43. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-6-25 07:12:47 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jhq999 于 2022-6-25 09:30 编辑

看看
  1. #include <bits/stdc++.h>
  2. using namespace std;

  3. int l, la, lb;
  4. string f, s;
  5. char op;

  6. short a[2002], b[2002], ans[4004];//////////////感觉这里变量类型用char就行了,9*9<255

  7. void read(){ //把读入字符串转倒序数组
  8.     memset(a, 0, sizeof(a)); memset(b, 0, sizeof(b)); memset(ans, 0, sizeof(ans));
  9.     la = f.size(); lb = s.size(); l = la + lb;
  10.     for(int i = la - 1; i >= 0; i--) a[la-i-1] = f[i] - '0';
  11.     for(int i = lb - 1; i >= 0; i--) b[lb-i-1] = s[i] - '0';
  12. }

  13. void print(short x[]){ //打印答案
  14.     int num = 4004;
  15.     while(!ans[num] && num > 0) --num;
  16.     for(int i = num; i >= 0; i--) cout << ans[i];
  17.     cout << endl;
  18. }

  19. void mul(short x[], short y[]){
  20.     // 这里直接计算结果中的从低到高第 i 位,且一并处理了进位
  21.     // 第 i 次循环为 c[i] 加上了所有满足 p + q = i 的 a[p] 与 b[q] 的乘积之和
  22.     for(int i = 0; i < la; i++){/////////////////////////////////
  23.         for(int j = 0; j <lb; j++){////////////////////////////

  24.             ans[i+j] += x[i] * y[j];
  25.         }
  26.         for(int k=0;k<lb;k+=1)///////////////////////////////////////
  27.         {
  28.             if(ans[i+k]>9)
  29.             {
  30.                 ans[i+k+1]+=ans[i+k]/10;
  31.                 ans[i+k]=ans[i+k]%10;
  32.             }
  33.         }
  34.     }
  35. }

  36. int main(){
  37.     ios::sync_with_stdio(0);
  38.     cin >> f >> s;
  39.     read();
  40.     mul(a, b);
  41.     print(ans);
  42.     return 0;
  43. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-6-25 12:10:37 | 显示全部楼层

就是被乘数每一位乘完之后就把每一位变成10以内的?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-6-25 12:21:33 | 显示全部楼层

懂了 , 谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-25 12:59:58 | 显示全部楼层
柿子饼同学 发表于 2022-6-25 12:10
就是被乘数每一位乘完之后就把每一位变成10以内的?

就是模拟竖式计算
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-17 00:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表