题目:http://acm.hdu.edu.cn/showproblem.php?pid=1753

本题要求是,进行多位的小数加法,由于位数很多,所以不能用double类型存储,可以用字符串存储,然后模拟小数的计算过程.通过一个例子,说明一下我的解题思路:

例如,计算1.2345 + 678.9,思路如下:

去掉小数点之前,记录小数点的位置,当做整数相加的结果,根据小数点的位置,按照小数的形式输出.

C++代码如下:

#include<iostream>
#include<string>
using namespace std; #define max(a,b) (a>b?a:b) int main()
{
string s1,s2;
while(cin>>s1>>s2)
{
int i,j;
int len_1 = s1.length();
int len_2 = s2.length(); for(i=0;i<len_1;i++)
if(s1[i]=='.')
break;
int int_len_1 = i;//s1的整数位长度
int decimal_len_1 = len_1 - int_len_1 - 1;//s1的小数位长度 for(i=0;i<len_2;i++)
if(s2[i]=='.')
break;
int int_len_2 = i;//s2的整数位长度
int decimal_len_2 = len_2 - int_len_2 - 1;//s2的小数位长度 //补齐整数位,使s1和s2的整数位对齐
if(int_len_1<int_len_2)
for(i=1;i<=int_len_2-int_len_1;i++)
s1 = '0' + s1;
else if(int_len_2<int_len_1)
for(i=1;i<=int_len_1-int_len_2;i++)
s2 = '0' + s2; //在s1和s2的前面多加1位0,因为例如:2.6+7.5 = 10.1整数位数变多了.
s1 = '0' + s1;
s2 = '0' + s2; //补齐小数位,使s1和s2小数位对齐
if(decimal_len_1<decimal_len_2)
for(i=1;i<=decimal_len_2-decimal_len_1;i++)
s1 = s1 + '0';
else if(decimal_len_2<decimal_len_1)
for(i=1;i<=decimal_len_1-decimal_len_2;i++)
s2 = s2 + '0'; int node = max(int_len_1,int_len_2)+1;//小数点的下标 //去掉小数点
s1 = s1.erase(node,1);
s2 = s2.erase(node,1); //下面,可以将s1和s2进行整数加法计算.
//模拟"整数"s1和s2的加法过程,结果存在s1中
int len = s1.length();
int c = 0;
for(i=len-1;i>=0;i--)
{
int x = s1[i] - '0';//将s1的某个字符转化为字符对应的数字
int y = s2[i] - '0'; c += (x+y);
s1[i] = (c % 10 + '0');//注意 +'0'是将数字 c%10 转化为对应的字符 c /= 10;
} //至此,计算完毕,下面是输出过程. for(i=0;i<len;i++)
if(s1[i]!='0')//从非零的整数位开始输出
break;
for(j=i;j<node;j++)
cout << s1[j];//输出整数位 for(j=len-1;j>=node;j--)//看看小数为是否都为0
if(s1[j]!='0')
break;
if(j>=node)//在这种情况下,小数为不全为0
{
cout << ".";//输出小数点
for(i=node;i<=j;i++)
cout << s1[i];//输出小数位
} cout << endl;
} return 0;
}

上述代码,提交可以通过.

【hdoj_1753】大明A+B(大数)的更多相关文章

  1. HDU中大数实现的题目,持续更新(JAVA实现)

    HDU1002:大数加法,PE了N次 import java.util.Scanner; import java.math.*; public class Main { public static v ...

  2. 大明A+B(hdu1753)大数,java

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

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

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

  4. (大数 小数点) 大明A+B hdu1753

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

  5. 大明A+B(大数相加)解题报告

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

  6. HDUOJ-------1753大明A+B(大数之小数加法)

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

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

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

  8. hdu 1753 大明A+B(高精度小数加法)

    //深刻认识到自己的粗心,为此浪费了一天.. Problem Description 话说,经过了漫长的一个多月,小明已经成长了许多,所以他改了一个名字叫"大明". 这时他已经不是 ...

  9. 大数问题,通常用JAVA

    e.g. HDU1002 简单加法 import java.math.BigInteger; import java.util.Scanner; public class Main { public ...

随机推荐

  1. 20135239益西拉姆 Linux内核分析 操作系统是怎样工作的?

    益西拉姆+ 原创作品+ <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 ” 堆栈 堆栈是C语言程序运行时 ...

  2. mysql主从配置的过程

    首先参考MySQL5.5官方手册 以下章节: 6.4节如何设置复制 13.6.1节 用于控制主服务器的SQL语句 13.6.2节 用于控制从服务器的SQL语句 6.8节 复制启动选项 6.5节 不同M ...

  3. oracle 远程登录sqlplus TNS:无监听

    1.将localhost 改成 计算机名 best-PC,或者ip地址 .  我修改成计算机名,因为经常在无线网络和有限网络之间切换 SID_LIST_LISTENER =  (SID_LIST =  ...

  4. python基础----迭代器、生成器、协程函数及应用(面向过程实例)

    一.什么是迭代器协议 1.迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前退) 2.可迭代 ...

  5. tableau学习

    一.维度 度量 1. 连接到新数据源时,Tableau 会将该数据源中的每个字段分配给“数据”窗格的“维度”区域或“度量”区域,具体情况视字段包含的数据类型而定. 例如: 2. tableau中的字段 ...

  6. linux小命令集合

    du -sh *  查看当前目录下的当前子目录的内存大小 df -h  查看内存占用情况 tar -xvf src.tgz ;    rsync -avzL   src/  desc/     lin ...

  7. Linux iptables:场景实战一

    <Linux iptables:规则原理和基础>和<Linux iptables:规则组成>介绍了iptables的基础及iptables规则的组成,本篇通过实际操作进行ipt ...

  8. vim 到文件开头 结尾

    gg:命令将光标移动到文档开头 G:命令将光标移动到文档末尾

  9. socket--粘包

    参考博客:http://www.cnblogs.com/kex1n/p/6502002.html 一.粘包现象 在上一篇的socket传输大数据文章中,我们可以顺利的接发数据,似乎做的不错,可以接收了 ...

  10. 简单实现VUE的双向数据绑定

    <!DOCTYPE html> <html> <head> <title>vue-双向数据绑定的简单实现</title> </head ...