| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 437 人关注过本帖
标题:大数的乘法。。
只看楼主 加入收藏
Agdmeg
Rank: 4
来 自:四川成都
等 级:业余侠客
威 望:3
帖 子:101
专家分:201
注 册:2011-8-9
结帖率:92.31%
收藏
已结贴  问题点数:20 回复次数:1 
大数的乘法。。
#include <stdio.h>
#include <string.h>
void main()
{
    int result[100][100],i,len1,len2,cbit=0,k,lenr,l=0,temp,cout=0,t,n;
    char num1[100]="",num2[100]="";
    gets(num1);
    gets(num2);
    len1=strlen(num1);
    len2=strlen(num2);
    lenr=len1+len2-1;
    t=lenr;
    for(i=0;i<=99;i++)
    {
        for(k=0;k<=99;k++)
            result[i][k]=-1;
    }
    for(i=len2-1;i>=0;i--)
    {
        for(k=len1-1;k>=0;k--)
        {
            temp=(num1[k]-48)*(num2[i]-48)+cbit;
            if(temp<=9)
            {
                result[cout][t-l]=temp;
                l++;
                cbit=0;
            }
            else if(temp>=10)
            {
                result[cout][t-l]=temp%10;
                temp/=10;
                cbit=temp;
                l++;
            }
        }
        if(cbit!=0)
            result[cout][t-l]=cbit;
        cout++;
        l=0;
        t--;
        cbit=0;
    }
    printf("\n");
    for(i=len1;i<=lenr+1;i++)
        printf(" ");
    printf("%s\n",num1);
    printf("x");
    for(i=len2;i<=lenr;i++)
        printf(" ");
    printf("%s\n",num2);
    for(i=0;i<=lenr+1;i++)
        printf("-");
    printf("\n");
    for(i=0;i<=cout-1;i++)
    {
        printf(" ");
        for(k=0;k<=lenr;k++)
        {
            if(result[i][k]!=-1)
            {
                for(n=0;n<=len1+1;n++)
                {
                    if(result[i][k+n]!=-1)
                        printf("%d",result[i][k+n]);
                }
                break;
            }
            printf(" ");
        }
        printf("\n");
    }
    for(i=0;i<=lenr+1;i++)
        printf("-");
    printf("\n");
    getch();
}
大数的乘法,还差最后求和一步没写,我的方法大家一看就懂,就是小学算法,有没有其他的算法?
输入两个大数:
852112115498455
11458912540545
结果:
图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: include result 
2013-05-15 01:18
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:20 
貌似没啥太好的方法

DO IT YOURSELF !
2013-05-15 08:16
快速回复:大数的乘法。。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024846 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved