付翔的专栏
在鄙视中成长 记录成长的点滴
posts - 106,  comments - 32,  trackbacks - 0
  

小数的精度的加法 很自然的和整数的加法连在一起 于是 就把小数点隔开,分成两部分加 。。只是在小数部分加的时候 进位 细节处理不当导致很多错误 也算是一次教训吧 。。。
因为 中途修改过很多 代码看起来 有点乱 呵呵
 

#include
<stdio.h>
#include
<string.h>
#include
<stdlib.h>

void partition_string(char _a[],char _a1[],char _a2[])
{
    
char *str;
    
int i,j,len;
    str 
= strchr(_a,'.');// 
    if(str!=NULL)
    {
        len 
= strlen(_a);//len = strlen(str);//这是错误的源泉 对于 1.1234567  这个是得到 .1234567的长度 
        strncpy(_a1,_a,(str-_a)/sizeof(char));
        _a1[(str
-_a)/sizeof(char)] = '\0';
        
        
for(j = 0, i = (str-_a)/sizeof(char+ 1;i< len;i++,j++)
            _a2[j] 
= _a[i];
        _a2[j] 
= '\0';
    }
    
else 
    {
        strcpy(_a1,_a);
        strcpy(_a2,
"");
    }

}
void supply(char _a[],int len)//对于小数区不足的以0补足 
{
    
int count = strlen(_a),i;
    
for(i = count ; i < len;i++)//for(i = count ; count < len;i++) 单步调试 才测出这个错误
        _a[i] = '0';
    _a[i] 
= '\0';
}
int check(char _str[])//这里貌似没有把0 去掉 而是换成了 空字符 for(k = i;k < len;k++) 
{    
    
/*12121213213124342545354545 13312312321312321321.02300000000000000000000000000
    这个测试数据 0.023 0000  后面的0 也会打印出来 因为for(k = i;k < len;k++) 这个我没有加 str[i]!='\0'
*/
    
int i,len = strlen(_str);
    
for(i = len-1;i>=0;i--)
    {
        
if(_str[i] == '0') _str[i] = '\0';
        
else return i;
        
//if(_str[i] != '0' ) break;
    }
    
//_str[i+1] = '\0'; 
    
//if(i == 0) return 0;
    return -1;
}
void add(char a[],char b[],char back[])//大数 加
{
    
int i,j,k,up,x,y,z,l;
    
char *c;
    
if (strlen(a)>strlen(b)) l=strlen(a)+2else l=strlen(b)+2;
    c
=(char *) malloc(l*sizeof(char));
    i
=strlen(a)-1;
    j
=strlen(b)-1;
    k
=0;up=0;
    
while(i>=0||j>=0)
    {
        
if(i<0) x='0'else x=a[i];
        
if(j<0) y='0'else y=b[j];
        z
=x-'0'+y-'0';
        
if(up) z+=1;
        
if(z>9) {up=1;z%=10;} else up=0;
        c[k
++]=z+'0';
        i
--;j--;
    }
    
if(up) c[k++]='1';
    i
=0;
    c[k]
='\0';
    
for(k-=1;k>=0;k--)
        back[i
++]=c[k];
    back[i]
='\0';


int main()
{
    
//freopen("in.txt","r",stdin);
    char a[500],b[500],temp[10];
    
char sum1[500],sum2[500];
    
char a1[500],a2[500],b1[500],b2[500];
    
char *str,*str2;int len,lena,lenb,i,j,k,l,num;
    
while(scanf("%s%s",a,b)!=EOF)
    {
        memset(a1,NULL,
500);memset(a2,NULL,500);//这个其实可以去掉
        memset(b1,NULL,
500);memset(b2,NULL,500);
        partition_string(a,a1,a2);partition_string(b,b1,b2);
        lena 
= strlen(a2);lenb=strlen(b2);
        len 
= lena>lenb?lena:lenb;
        
if(lena < lenb)
            supply(a2,len);
        
else if(lena > lenb)
            supply(b2,len);
        add(a2,b2,sum2);
        add(a1,b1,sum1);

        i 
= 0;
        
if( len < strlen(sum2) )
            i 
= 1,num = sum2[0]-'0';
        
if(i == 1)
        {
            
/*k = sum1[strlen(sum1)-1] - '0';//这里的进位考虑不周到
            sum1[strlen(sum1)-1] = (k+num)%10 + '0';
            if(k + num > 9)
                sum1[strlen(sum1)-2]+=1;
*/
            
for(j = strlen(sum1)-1; j>=0 ;j--//考虑 xxx99999 进位的情况
            {
                k 
= sum1[j] - '0';
                
if(k + num > 9) {sum1[j] =  (k+num)%10 + '0'; num = 1;}
                
else {sum1[j] = k + num + '0';break;}
            }
            
if(j == -1)//如果 出现 整数是99999 然后进了一位 这样的情况
                printf("1");
        }
        printf(
"%s",sum1);
        
if(check(sum2) > 0 ||(check(sum2) == 0 && i!=1))  printf(".");
        len 
= strlen(sum2);
        
for(k = i;k < len && sum2[k]!='\0';k++)
            printf(
"%c",sum2[k]);
        printf(
"\n");
        memset(a,NULL,
500);memset(b,NULL,500);

    }
    
return 0;
}


posted on 2010-04-24 13:35 付翔 阅读(1475) 评论(0)  编辑 收藏 引用 所属分类: ACM 数据结构

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理



<2010年4月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

常用链接

留言簿(2)

随笔分类

随笔档案

文章分类

文章档案

CSDN - 我的blog地址

博客

搜索

  •  

最新评论

阅读排行榜

评论排行榜