Chinaunix首页 | 论坛 | 博客
  • 博客访问: 352840
  • 博文数量: 90
  • 博客积分: 2017
  • 博客等级: 大尉
  • 技术积分: 615
  • 用 户 组: 普通用户
  • 注册时间: 2009-10-19 08:10
文章分类

全部博文(90)

文章存档

2012年(4)

2011年(74)

2010年(11)

2009年(1)

分类: C/C++

2011-08-20 19:29:27

上面大整数已经写了.你加几个东西就行了. 
#include   
using   namespace   std;   
#define   MAX   10000   
struct   Node{   
      int   data;   
      Node   *next;   
};   
void   output(Node   *head,int   pos)   
{   
      if(!head-> next&&!head-> data)return;   
      output(head-> next,pos-1);   
      cout < data; 
      if(!pos)cout < < ". "; 
}   
void   Mul(char   *a,char   *b,int   pos)                   
{   
      char   *ap=a,*bp=b;   
      Node   *head=0;   
      head=new   Node;head-> data=0,head-> next=0;       //头   
      Node   *p,*q=head,*p1;   
      int   temp=0,temp1,bbit;   
      while(*bp)                                 //若乘数不为空   ,继续.   
      {   
              p=q-> next;p1=q;   
              bbit=*bp-48;                     //把当前位转为整型   
              while(*ap||temp)                         //若被乘数不空,继续   
              {   
                      if(!p)                         //若要操作的结点为空,申请之   
                      {   
                              p=new   Node;   
                              p-> data=0;   
                              p-> next=0;   
                              p1-> next=p;   
                      }   
                      if(*ap==0)temp1=temp;   
                      else   {   temp1=(p1-> data)+(*ap-48)*bbit+temp;ap++;   }   
                      p1-> data=temp1%10;         //留当前位   
                      temp=temp1/10;         //进位以int的形式留下.   
                      p1=p;p=p-> next;                                   //被乘数到下一位   
              }   
              ap=a;bp++;q=q-> next;                                 //q进下一位   
      }   
      p=head;   
      output(p,pos);                                       //显示   
      cout <       while(head)                                   //释放空间   
      {   
                      p=head-> next;   
                      delete   head;   
                      head=p;   
      }   
}   
int   main()   
{   
      cout < < "请输入两个数 " <       char   test1[MAX],test2[MAX],*p;   
      int   pos=0; 
      cin.getline(test1,MAX, '\n ');   
      cin.getline(test2,MAX, '\n '); 
      if(p=strchr(test1, '. ')) 
      { 
              pos+=strlen(test1)-(p-test1)-1;   
              do 
              { 
                      p++; 
                      *(p-1)=*p; 
              }while(*p); 
      }                 
      if(p=strchr(test2, '. ')) 
      { 
              pos+=strlen(test2)-(p-test2)-1; 
              do 
              { 
                      p++; 
                      *(p-1)=*p; 
              }while(*p); 
      }         
      Mul(strrev(test1),strrev(test2),pos);   
      system( "PAUSE ");   
      return   0;   
}   
阅读(2013) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~