//深刻认识到自己的粗心,为此浪费了一天。。

Problem Description
话说,经过了漫长的一个多月,小明已经成长了许多,所以他改了一个名字叫“大明”。

这时他已经不是那个只会做100以内加法的那个“小明”了,现在他甚至会任意长度的正小数的加法。



现在,给你两个正的小数A和B,你的任务是代表大明计算出A+B的值。
 
Input
本题目包含多组测试数据,请处理到文件结束。

每一组测试数据在一行里面包含两个长度不大于400的正小数A和B。
 
Output
请在一行里面输出输出A+B的值,请输出最简形式。详细要求请见Sample Output。
 
Sample Input
1.1 2.9
1.1111111111 2.3444323343
1 1.1
 
Sample Output
4
3.4555434454
2.1
 
Author
linle
 

/*************************

继续大数,这次是大 小数,

我用了一个结构体 分别存放 小数的  整数部分 和 小数部分,两个数组,分别相加,进位 分别处理,同时要注意  
前导0   和  后导0
 的处理。。详细看代码

************************/

//  小数 位的加法有问题

#include <iostream>
#include <string.h>
#include <stdio.h>
using namespace std;
#define N 8000
struct Bint// 大数的结构体
{
int high[N/2];// 存放整数位
int low[N/2];// 存放小数位
int p;// 整数位非零位数
int del; // 小数位非零位数
};
int Find(char a,char str[])// 找小数点的位置,实际返回的是整数部分的位数
{
int i,len = strlen(str);
for(i = 0;i<len;i++)
if(str[i]==a)
return i;
return len;// 整数时直接返回 长度
} void print(struct Bint s)// 输出函数
{
int i;
for(i = s.p-1;i>=0;i--)
printf("%d",s.high[i]);
if(s.del>0){
printf(".");
for(i = 0;i<s.del;i++)
printf("%d",s.low[i]);
}
printf("\n");
}
void trans(Bint &a,char str[])// 将输入的字符串形式的数 转换为结构体
{
memset(a.high,0,sizeof(a.high));
memset(a.low,0,sizeof(a.low));
int len = strlen(str);
a.p = Find('.',str);
a.del = (len==a.p)?0:(len-a.p-1);// 如果包含小数点则小数位数为 数的长度-整数位数-1
int i=0,ii = 0,jj = 0,pa= a.p,l = len-1;
while(str[i++]=='0'&&i<pa)// 去除前导0
a.p--;
while(str[l--]=='0'&&l>=pa)// 去除 后导 0
a.del--;
for(i = pa-1;i>=pa-a.p;i--)// 整数位赋值
a.high[ii++] = str[i]-'0';
for(i = pa+1;i<pa+1+a.del;i++)// 小数位 赋值
a.low[jj++] = str[i]-'0';
}
void add(char A[],char B[])// 加法 代码核心
{
int i;
Bint a,b,ans;// ans 存 结果
memset(ans.low,0,sizeof(ans.low));
memset(ans.high,0,sizeof(ans.high));
trans(a,A);
trans(b,B);
ans.p = (a.p>b.p)?a.p:b.p;// 取a,b 整数位的最大值
ans.del = (a.del>b.del)?a.del:b.del;// 同上,取小数位
// 以下两个循环为逐位相加的过程
for(i = 0;i<ans.p;i++)
ans.high[i] = a.high[i]+b.high[i];
for(i = 0;i<ans.del;i++)
ans.low[i] = a.low[i]+b.low[i];
// 进位处理
for(i = ans.del-1;i>0;i--)
{
if(ans.low[i]>=10)
{
ans.low[i-1]+=ans.low[i]/10;
ans.low[i]%=10;
}
}
//小数位第一位有进位时的处理
if(ans.low[0]>=10)
{
ans.high[0]+=ans.low[0]/10;
ans.low[0]%=10;
}
for(i = 0;i<ans.p;i++)
{
if(ans.high[i]>=10)
{
ans.high[i+1]+=ans.high[i]/10;
ans.high[i]%=10;
}
}
if(ans.high[ans.p]>0)
ans.p+=1;
// 相加以后产生后导 0 的处理
while(ans.low[ans.del-1]==0)
ans.del--;
print(ans);
}
int main()
{
char A[N],B[N];
while(cin>>A>>B)
{
add(A,B);
}
return 0;
}

hdu 1753 大明A+B(高精度小数加法)的更多相关文章

  1. HDU 1753 大明A+B (大正小数加法、字符串处理)

    大明A+B Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. FZU 2032 高精度小数加法

    题目描写很没意思..就是说给出n个小数 求它们的总和 因为给出的小数点后最多16位而要求保存至12位 而能直接使用的最精确的double只能到12位 于是13的进位可能被忽略 于是不可以用double ...

  3. hdoj 1753 大明A+B 高精度/java

    大明A+B Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  4. [HDOJ] 1753.大明A+B (大数加法)

    Problem Description 话说,经过了漫长的一个多月,小明已经成长了许多,所以他改了一个名字叫"大明". 这时他已经不是那个只会做100以内加法的那个"小明 ...

  5. hdu 1753 大明A+B

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1753 容易出错的事例: 0.1 0.2 1.88 22.22 1 0.01 大概出错的几个点,做久了思维根 ...

  6. hdu 1753 大明A+B(大数)

    题意:小数大数加法 思路:大数模板 #include<iostream> #include<stdio.h> #include<string.h> using na ...

  7. HDU 1753 大明A+B(字符串模拟,简单题)

    简单题,但要考虑一些细节: 前导0不要,后导0不要,小数长度不一样时,有进位时,逆置处理输出 然后处理起来就比较麻烦了. 题目链接 我的代码纯模拟,把小数点前后分开来处理,写的很繁杂,纯当纪念——可怜 ...

  8. hdu 1316 How many Fibs?(高精度斐波那契数)

    //  大数继续 Problem Description Recall the definition of the Fibonacci numbers:  f1 := 1  f2 := 2  fn : ...

  9. BigDecimal类(高精度小数)

    位置:java.math.BigDecimal 作用:提供高精度小数数据类型及相关操作 一.基本介绍 BigDecimal为不可变的.任意精度的有符号十进制数,其值为(unscaledValue * ...

随机推荐

  1. PowerDesigner 业务处理模型( BPM )

    PowerDesigner 业务处理模型( BPM ) 说明 properties语言文档xmlvalidation数据库   目录(?)[+]   一.     BPM 简介 业务处理模型(Busi ...

  2. Struts中文件的上传与下载

    前面学到的用组件去上传 前台: 1.post表单提交 2.表单类型 multipart/form-data 3.intput type=file 后台: Apach提供的FileUpload组件 核心 ...

  3. hadoop的hdfs文件操作实现上传文件到hdfs

    这篇文章主要介绍了使用hadoop的API对HDFS上的文件访问,其中包括上传文件到HDFS上.从HDFS上下载文件和删除HDFS上的文件,需要的朋友可以参考下hdfs文件操作操作示例,包括上传文件到 ...

  4. HOG特征-理解篇

    网上去找关于HOG的资料,发现理解性的较少,并且较为冗长,为方便大家理解便自己写了篇,希望能对奋斗在特征提取第一线的同志们有所帮助: HOG即histogram of oriented gradien ...

  5. 【源码分享】iOS-OC版五子棋

    五子棋是程序猿比较熟悉的一款小游戏,相信很多人大学时期就用多种语言写过五子棋小游戏,笔者工作闲暇之余,试着用OC实现了一下,在这里给大家分享一下.有不足之处,欢迎大家提供建议和指点! GitHub源码 ...

  6. Linux性能实时监测工具 Netdata

    http://www.oschina.net/p/netdata?fromerr=hjJMgUjE#rd

  7. PHP中的全局变量$_SERVER

    1.常用 $_SERVER['PHP_SELF'] #当前正在执行脚本的文件名,与 document root相关.$_SERVER['argv'] #传递给该脚本的参数.$_SERVER['argc ...

  8. Java基础知识强化之IO流笔记67:Properties的特殊功能使用

    1. Properties的特殊功能 public Object setProperty(String key,String value):添加元素 public String getProperty ...

  9. 键盘工具栏的快速集成--HcCustomKeyboard

    源项目地址:HcCustomKeyboard HcCustomKeyboard是一个键盘工具栏控件: 效果: HcCustomKeyboard使用很方便: 三部: 添加控件->操作处理-> ...

  10. C语言创建并使用lib

    本文试图以比较简洁的方式创建lib: 只求能够把lib用起来,并不会加上[很多但必须的东西,比如我们之前说过的#ifndef #define 和#endif] 打开vs 创建一个新的项目: 点击确定 ...