posts - 20,  comments - 6,  trackbacks - 0
  1#include<stdio.h>
  2#include<string.h>
  3char *add(char s1[],char s2[]) 
  4{
  5    char str1[1100],str2[1100],str3[1100];
  6    int t1,t2,i,save=0,j;        
  7    strcpy(str1,strlen(s1)>=strlen(s2)?s1:s2);
  8    strcpy(str2,strlen(s1)<strlen(s2)?s1:s2);
  9    t1=strlen(str1);
 10    t2=strlen(str2);
 11    for(i=1;i<=t2;i++)
 12        str1[t1-i]+=(str2[t2-i]-'0');
 13    for(i=t1-1;i>=0;i--)
 14        if(str1[i]>'9')
 15        {
 16            str1[i]=(str1[i]-'0')%10+'0';
 17            if(i!=0) str1[i-1]++;
 18            else save=1;
 19        }

 20        t1=strlen(str1);j=0;
 21        if(save!=1)
 22        return str1; 
 23        if(save==1)
 24        
 25         j=1;
 26            for(i=0;i<t1;i++)  
 27            {str3[j]=str1[i];j++;}
 28            str3[0]='1';
 29            str3[j]='\0';
 30        return str3;
 31        }
    
 32}
 
 33int main()
 34{
 35    char a[800],b[800];
 36    int la,lb,i,j,k,l,pa,pb,l2,p,lb1,lb2;
 37    char az[800],ax[800],bz[800],bx[800],anz[800],anx[800];
 38    while(scanf("%s%s",a,b)!=EOF)
 39    {
 40        memset(az,0,sizeof(az));
 41        memset(anz,0,sizeof(anz));
 42        memset(anx,0,sizeof(anx));
 43        memset(ax,0,sizeof(ax));
 44        memset(bz,0,sizeof(bz));
 45        memset(bx,0,sizeof(bx));
 46        la=strlen(a);
 47        pa=pb=0;
 48        lb=strlen(b);
 49        j=k=0;
 50        for(i=0;i<la;i++)
 51        {
 52            if(a[i]=='.')
 53            {
 54                pa=1;
 55                continue;
 56            }

 57            if(pa==0)
 58            {
 59                az[j]=a[i];
 60                j++;
 61            }

 62            if(pa)
 63            {
 64                ax[k]=a[i];
 65                k++;
 66            }

 67        }

 68            j=k=0;
 69        for(i=0;i<lb;i++)
 70        {
 71            if(b[i]=='.')
 72            {
 73                pb=1;
 74                continue;
 75            }

 76            if(pb==0)
 77            {
 78                bz[j]=b[i];
 79                j++;
 80            }

 81            if(pb)
 82            {
 83                bx[k]=b[i];
 84                k++;
 85            }

 86        }

 87        strcpy(anz,add(az,bz));
 88        l=strlen(ax);
 89        for(i=strlen(ax);i>=0;i--)
 90        {
 91            ax[i]=ax[i-1];
 92        }

 93        ax[0]='1';
 94        a[l+1]='\0';
 95        l=strlen(bx);
 96        for(i=l;i>=0;i--)
 97        {
 98            bx[i]=bx[i-1];
 99        }

100        bx[0]='1';
101        b[l+1]='\0';
102        if(strlen(ax)!=strlen(bx))
103        {
104            lb1=strlen(ax);
105            lb2=strlen(bx);
106            if(lb1>lb2)
107            {
108                for(i=lb2;i<lb1;i++)
109                {
110                    bx[i]='0';
111                }

112                bx[i]='\0';
113            }
else
114            {
115                for(i=lb1;i<lb2;i++)
116                {
117                    ax[i]='0';
118                }

119                ax[i]='\0';
120            }

121        }

122        strcpy(anx,add(ax,bx));
123        l2=strlen(bx)>strlen(ax)?strlen(bx):strlen(ax);
124        if(anx[0]=='2'&&strlen(anx)==l2)
125        {
126            l=strlen(anx);
127            for(i=0;i<l;i++)
128            {
129                anx[i]=anx[i+1];
130            }

131            anx[i]='\0';
132        }
else
133        {
134            l=strlen(anx);
135            for(i=0;i<l;i++)
136            {
137                anx[i]=anx[i+1];
138            }

139            anx[i]='\0';
140            strcpy(anz,add(anz,"1")); 
141        }

142        l=strlen(anx);
143        for(i=l-1;i>=0;i--)
144        {
145            if(anx[i]!='0')
146            {
147                break;
148            }
else
149            {
150                anx[i]='\0';
151            }

152        }

153        l=strlen(anz);
154        for(i=0;i<l;i++)
155        {
156            if(anz[i]!='0')
157            {
158                break;
159            }
else
160            {
161                for(j=0;j<l;j++)
162                {
163                    anz[j]=anz[j+1];
164                }

165                i--;
166                anz[j]='\0';
167            }

168        }

169        if(!anz[0])
170        {
171            anz[0]='0';
172            anz[1]='\0';
173        }

174        if(anx[0])
175            printf("%s.%s\n",anz,anx);
176        else
177            puts(anz);
178    }

179}

180
posted on 2009-01-27 14:11 混沌的云 阅读(491) 评论(0)  编辑 收藏 引用

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


<2024年11月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

常用链接

留言簿(1)

随笔档案

搜索

  •  

最新评论

阅读排行榜

评论排行榜