免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3144 | 回复: 4
打印 上一主题 下一主题

[算法] 关于大数乘法的解决方案,大家来帮我看一看这样做的好处和坏处 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-11-13 00:43 |只看该作者 |倒序浏览
我的算法比较简单,用一个简单的例子,其实原理差不多:
char a[5];
char b[5];       //存放两个乘数
char result[10];  //存放结果

不说太多,不早了,直接上程序:
/*
* multiplication.c
*
*  Created on: 2013年11月13日
*      Author: root
*/

#include<stdio.h>

int main()                                                         
{
        char a[5] = {'1','2','3','4','5'};
        char b[5] = {'1','2','3','4','5'};

        char res[10];
        char p[5][5];

        int i,j;
        int buf = 0;
        int add = 0;
        int buf1 = 0;
        for(i = 0;i < 5;i++)
        {
                for(j = 4;j >= 0;j--)                           //用a与b的每一位相乘,放进数组里
                {
                        p[i][j] = (a[j]-'0') * (b[4-i] - '0');               
                        buf1 = p[i][j];
                        p[i][j] = buf1%10 + buf;
                        if(p[i][j] > 9)
                        {
                                add = 1;
                                p[i][j] = p[i][j] -10 +'0';
                        }
                        else
                        {
                                add = 0;
                                p[i][j] = p[i][j] +'0';
                        }
                        buf = buf1/10 + add;
                }
                buf = 0;
        }

        for(i = 0;i < 5;i++)
        {
                for(j = 0; j < 5;j++)
                {
                        printf("%c ",p[i][j]);
                }
                printf("\n";                                  //打印出五个数组的内容
        }
}

整合的过程比较简单就不写了,你们帮我看看这个算乘法怎么样?谢谢啊 晚安,各位


论坛徽章:
1
综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00
2 [报告]
发表于 2013-11-13 05:02 |只看该作者
-bash-4.1$ expr 12345 \* 12345
152399025

-bash-4.1$ ./Multiply
6 1 7 2 5
4 9 3 8 0
3 7 0 3 5
2 4 6 9 0
1 2 3 4 5

你这程序打印了这一堆,计算的结果”152399025“在哪里??

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
3 [报告]
发表于 2013-11-13 12:06 |只看该作者
回复 1# lyyiqo

速度慢。
你至少要学学openssl里边的BN,大数运算。

   

论坛徽章:
0
4 [报告]
发表于 2013-11-13 23:53 |只看该作者
计算结果要自己加一下的,每下一维左移一位,昨天太晚了就没弄
回复 2# fly3ds


   

论坛徽章:
0
5 [报告]
发表于 2013-11-13 23:54 |只看该作者
谢谢啊,我会看一下的
回复 3# yulihua49


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

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP