HDOJ 1753 明朝A+B
http://acm.hdu.edu.cn/showproblem.php?
pid=1753
大明A+B
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 8296 Accepted Submission(s): 2929
这时他已经不是那个仅仅会做100以内加法的那个“小明”了。如今他甚至会随意长度的正小数的加法。
如今,给你两个正的小数A和B,你的任务是代表大明计算出A+B的值。
每一组測试数据在一行里面包括两个长度不大于400的正小数A和B。
具体要求请见Sample Output。
1.1 2.9
1.1111111111 2.3444323343
1 1.1
4
3.4555434454
2.1
先计算小数位的和,由于十分位可能向各位进位,进位时a[0]+=1即可。然后后边直接用;
然后计算整数位的和。也就是大数相加,仅仅是应该注意把字符串中的数存到a[]时。要写成a[j]+=s1[i]-'0',由于要考虑进位
/*思路清晰,算法仅仅用到了大数,但里边须要注意的地方非常多
先计算小数位的和。由于十分位可能向各位进位,进位时a[0]+=1即可,然后后边直接用;
然后计算整数位的和,也就是大数相加,仅仅是应该注意把字符串中的数存到a[]时。要写成a[j]+=s1[i]-'0',由于要考虑进位
*/
#include<stdio.h>
#include<string.h>
#define MAX 450
int main()
{
int a[MAX],b[MAX],num_1[MAX],num_2[MAX],i,j,k,n;
char s1[MAX],s2[MAX];
while(~scanf("%s %s",s1,s2))
{
memset(num_1,0,sizeof(num_1));
memset(num_2,0,sizeof(num_2));
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
n=strlen(s1);
for(i=0;i<n;i++)//s1[i]为小数点
if(s1[i]=='.') break;
for(k=0,j=n-1;j>i;j--,k++)//s1有k位小数
num_1[k]=s1[j]-'0';
int i_1=i,k_1=k,n_1=n; n=strlen(s2);
for(i=0;i<n;i++)//s2[i]为小数点
if(s2[i]=='.') break;
for(k=0,j=n-1;j>i;j--,k++)//s2有k位小数
num_2[k]=s2[j]-'0';
int i_2=i,k_2=k,n_2=n;
if(k_1>=k_2)//小数相加,注意十分位进位的情况 //分两这情况(k_1>=k_2)和(k_1<k_2)是由于不确定哪个小数点后的位数大
{//假设k_1>=k_2,把计算的结果放到num_1[]中
for(i=k_1-k_2,j=0;i<k_1;i++,j++)
{
num_1[i]+=num_2[j];
if(num_1[i]>=10)
{
num_1[i]-=10;
num_1[i+1]+=1;
}
//printf("%d#\n",num_1[i]);
}
if(num_1[i]==1)//十分位进到个位
{
num_1[i]-=1;
a[0]+=1;
}
}
else if(k_2>k_1)//假设k_2>k_1,把计算的结果放到num_2中。 {
for(i=k_2-k_1,j=0;i<k_2;i++,j++)
{
num_2[i]+=num_1[j];
if(num_2[i]>=10)
{
num_2[i]-=10;
num_2[i+1]+=1;
} }
if(num_2[i]==1)//十分位进到个位
{
num_2[i]-=1;
a[0]+=1;
}
}
//上边小数位相加分两种情况。下边小数位的输出也分两种情况 for(j=0,i=i_1-1;i>=0;i--,j++)//这里是a[j]+=s1[i]-'0',由于考虑到小数会给a[0]进位。 a[j]+=s1[i]-'0'; //这里事实上仅仅给a[0]+=s1[o]-'0',其余还是a[j]=s1[i]-'0',仅仅是这样写和把a[0]独分出来效果一样,就这样写了
for(j=0,i=i_2-1;i>=0;i--,j++)//给b[0]赋值时和a[]一样
b[j]=s2[i]-'0';
for(i=0;i<MAX;i++)//计算整数部分。存到a[]中
{
a[i]+=b[i];
if(a[i]>=10)
{
a[i]-=10;
a[i+1]+=1;
}
}
for(i=MAX-1;i>0;i--)//输出整数部分
if(a[i]!=0) break;
for(;i>=0;i--)
printf("%d",a[i]); if(k_1>=k_2)//输出小数部分
{
for(i=k_1-1;i>=0;i--)//这里的for循环是推断小数点后是否有值,假设没有值,循环进行究竟。最后i是-1
if(num_1[i]!=0) break;//假设i==-1。则不运行下边if(i!=-1),也就是不输出小数点和小数点后边的0
for(j=0;j<k_1;j++)//这个for循环的作用是不输出计算得到的小数后边的0,如1.028+1.072。 在for之前结果是2.100,运行完for就把 后边的0去掉,结果为2.1
if(num_1[j]!=0) break;
if(i!=-1)//假设小数点后边有值,输出小数点和后边的数
{
printf(".");
for(i=k_1-1;i>=j;i--)
printf("%d",num_1[i]);
}
}
else if(k_1<k_2)//这里的if和上边一样
{
for(i=k_2-1;i>=0;i--)
if(num_2[i]!=0) break;
for(j=0;j<k_2;j++)
if(num_2[j]!=0) break;
if(i!=-1)
{
printf(".");
for(i=k_2-1;i>=j;i--)
printf("%d",num_2[i]);
}
}
printf("\n"); }
return 0;
}
/*
0 0
1.2333 1.2667
99999 1
12121213213124342545354545 13312312321312321321.02300000000000000000000000000
1.0001 1.00002
99999.889 0.111
1000.0 10000.0
112233.1 333.9
123450000 777
123400000 777.700
0.000 0.0000
1212121212.1111111 21212121.33300000000000000
*/
版权声明:本文博主原创文章。博客,未经同意不得转载。
HDOJ 1753 明朝A+B的更多相关文章
- hdoj 1753 大明A+B 高精度/java
大明A+B Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- HDOJ 1753 大明A+B
JAVA大数.... 大明A+B Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- [HDOJ] 1753.大明A+B (大数加法)
Problem Description 话说,经过了漫长的一个多月,小明已经成长了许多,所以他改了一个名字叫"大明". 这时他已经不是那个只会做100以内加法的那个"小明 ...
- hdoj 1753 (Java)
刚刚开始用Java,代码难免不够简洁. import java.math.BigDecimal; import java.util.Scanner; public class Main { publi ...
- 【HDOJ】1753 大明A+B
注意数据格式,可以是整数,并且注意输出最简化浮点数. #include <stdio.h> #include <string.h> #define MAXNUM 420 cha ...
- SqlDateTime overflow. Must be between 1/1/1753 12:00:00 AM and 12/31/9999 11:59:59 PM.
相信很多人进行数据存储时,会遇上如标题的异常错误. 其实也不算上一个错误. 当你的程序中有宣告一个字段的数据类型为DateTime时,但你又没有赋值给它,就进行存储时,它就会得到这样一个结果. 看看下 ...
- POJ 1753. Flip Game 枚举or爆搜+位压缩,或者高斯消元法
Flip Game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 37427 Accepted: 16288 Descr ...
- HDOJ 1009. Fat Mouse' Trade 贪心 结构体排序
FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDOJ 2317. Nasty Hacks 模拟水题
Nasty Hacks Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tota ...
随机推荐
- 使用Sublime Text 2编辑和运行node-webkit应用程序
开发工具目录结构 --E:\develop\ ----node-webkit-v0.9.2-win-ia32 ----Sublime Text 2.0.2 x64 为Sublime text2构建Bu ...
- java 线程 新类库中的构件 countDownLatch 使用
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGlhbmdydWkxOTg4/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- 如何解决Windows8.1(32bit&64bit)下Cisco VPN Client拨号时报442错误的问题
Cisco VPN Cient大多数网络管理员.技术支持project最流行的教师和最终用户VPNclient一间.对于外部网络访问内部网络,技术类人员. 随着Windows8.1的推出.Cisco ...
- HDU4309-Seikimatsu Occult Tonneru(最大流)
Seikimatsu Occult Tonneru Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- Cocos2d-x 3.2 大富翁游戏项目开发-第七部分 获取角色路径_1
以下是一些设计略显繁琐,有必要清除思维. 下一个主要的成就,当我们点击Gobutton后,得到一个随机数骰子,是走了几步,它是基于以下步骤行走路径的数目,然后移动位置的基于角色的路径. 流程如图普遍认 ...
- 移植 libuv 至 Visual C++ 6.0 并支持 Windows XP 编译系统
移植版本 libuv:https://github.com/liigo/libuv-vc6 (支持VC6和XP.作者Liigo). 我从一年前(大概2013年6,7月份)開始在业余时间做这项移植工作, ...
- ASP.NET Core 1.0 部署 HTTPS
ASP.NET Core 1.0 部署 HTTPS ASP.NET Core 1.0 部署 HTTPS (.NET Framework 4.5.1) 提示 更新时间:2016年01月23日. 在目前介 ...
- Linux下常用操作汇总
查看linux操作系统位数 (1) 终端输入: file /sbin/init 如 显示: /sbin/init: ELF 32-bit LSB executable, Intel 80386, ve ...
- 【原创】ZOJ_1649 Rescue 解题报告
Rescue Time Limit: 2 Seconds Memory Limit: 65536 KB Angel was caught by the MOLIGPY! He was put ...
- 解析DBR操作系统引导记录数据
理解文件系统.你必须要熟悉DBR,下面我们就来看看文件系统解析DBR数据. Dos Boot Record(DBR)操作系统引导记录是由操作系统的格式化程序建立的.在文件系统驱动操作不论什么一个磁盘卷 ...