免费注册 查看新帖 |

Chinaunix

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

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

论坛徽章:
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";                                  //打印出五个数组的内容
        }
}

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


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


   

论坛徽章:
0
3 [报告]
发表于 2013-11-13 23:54 |显示全部楼层
谢谢啊,我会看一下的
回复 3# yulihua49


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP