标题信息: 手动求大的实数在一起,

pid=1753">http://acm.hdu.edu.cn/showproblem.php?pid=1753

AC代码:

/**

 *大实数相加,以小数点为分界,模拟加法运算,最后合并

 */

#include<iostream>

#include<string>

#include<algorithm>

using namespace std;

string add(string s1,string s2){//字符串模拟大整数加法,模拟结果有前导0

    int i,j,len1,len2;

    len1=s1.size(); len2=s2.size();

    //寻找小数点的位置

    for(i=0;s1[i]!='.'&&i<len1;i++);

    for(j=0;s2[j]!='.'&&j<len2;j++);

    //cout<<i<<" "<<j<<endl;

    string s,ss;

    int flag=0;

    //模拟小数点后面的数相加

    len1--; len2--;

    while(len1-i>len2-j){

        int sum=flag+(s1[len1--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    //cout<<s<<endl;

    while(len2-j>len1-i){

        int sum=flag+(s2[len2--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    //使小数点后位数对齐之后相加

    int len11,len22;

    if(len1-i>len2-j){

       len11=len1-((len1-i)-(len2-j));

       len22=len2;

    }

    else{

        len22=len2-((len2-j)-(len1-i));

        len11=len1;

    }

    while(len11>i&&len22>j){

        int sum=flag+(s1[len11--]-'0')+(s2[len22--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    /**迭代器去除字符’0‘

    while(len11>i){

        int sum=flag+(s1[len11--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    while(len22>j){

        int sum=flag+(s2[len22--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    string::iterator it;//定义方向迭代器

    for(it=s.begin();*it=='0'&&it!=s.end();it++){//去掉s的前缀0,即小数后的0

        s.erase(it);

    }**/

    //cout<<s<<endl;

    string ss0;//用ss0去掉前导0

    int kk;

    for(kk=0;kk<s.size()&&(s[kk]=='0'||s[kk]=='.');kk++);

    for(int k=kk;k<s.size();k++) ss0+=s[k];

    //cout<<ss0<<endl;

    for(int i=0;i<ss0.size()/2;i++){

        char c=ss0[i];

        ss0[i]=ss0[ss0.size()-i-1];

        ss0[ss0.size()-i-1]=c;

    }

    //模拟小数点前面的数相加

    len1=i-1; len2=j-1;

    while(len1>-1&&len2>-1){

        int sum=flag+(s1[len1--]-'0')+(s2[len2--]-'0');

        ss+=char ((sum)%10+'0');

        flag=sum/10;

    }

    while(len1>-1){

        int sum=flag+(s1[len1--]-'0');

        ss+=char ((sum)%10+'0');

        flag=sum/10;

    }

    while(len2>-1){

        int sum=flag+(s2[len2--]-'0');

        ss+=char ((sum)%10+'0');

        flag=sum/10;

    }

    if(flag) ss+=char ('0'+flag);

    //cout<<s<<endl;

    for(int i=0;i<ss.size()/2;i++){

        char c=ss[i];

        ss[i]=ss[ss.size()-i-1];

        ss[ss.size()-i-1]=c;

    }

    //cout<<ss<<endl;

    if(!ss0.empty()&&ss0[0]!='.') ss=ss+'.'+ss0;

    if(!ss0.empty()&&ss0[0]=='.') ss=ss+ss0;

    return ss;

}

int main()

{

    string s1,s2;

    while(cin>>s1>>s2){

        cout<<add(s1,s2)<<endl;

    }

    return 0;

}

版权声明:本文博主原创文章,博客,未经同意不得转载。

hdu1753()模拟大型实景数字相加的更多相关文章

  1. pat(A) 2-06. 数列求和(模拟摆竖式相加)

    1.链接:http://www.patest.cn/contests/ds/2-06 2.思路:模拟摆竖式相加,因为同样位置上的数字同样,那么同一位上的加法就能够用乘法来表示 3.代码: #inclu ...

  2. [LeetCode] Add Two Numbers 两个数字相加

    You are given two linked lists representing two non-negative numbers. The digits are stored in rever ...

  3. [CareerCup] 2.5 Add Two Numbers 两个数字相加

    2.5 You have two numbers represented by a linked list, where each node contains a single digit. The ...

  4. 用字符串模拟两个大数相加——java实现

    问题: 大数相加不能直接使用基本的int类型,因为int可以表示的整数有限,不能满足大数的要求.可以使用字符串来表示大数,模拟大数相加的过程. 思路: 1.反转两个字符串,便于从低位到高位相加和最高位 ...

  5. js “+” 连接字符串&数字相加 数字相加出现多位小数 函数调用单引号双引号嵌套和转义字符的使用

    一.机制 JavaScript中,加号不仅表示相加还表示字符串连接 当加号两边存在字符串时,加号代表连接,实际上是将两侧都转为了字符串,如 "1" + 1 = "11&q ...

  6. 【CJOJ P1957】【NOIP2010冲刺十模拟赛】数字积木

    [NOIP2010冲刺十模拟赛]数字积木 Description 小明有一款新式积木,每个积木上都有一个数,一天小明突发奇想,要是把所有的积木排成一排,所形成的数目最大是多少呢? 你的任务就是读入n个 ...

  7. 给定一个整数,求解该整数最少能用多少个Fib数字相加得到

    一,问题描述 给定一个整数N,求解该整数最少能用多少个Fib数字相加得到 Fib数列,就是如: 1,1,2,3,5,8,13.... Fib数列,满足条件:Fib(n)=Fib(n-1)+Fib(n- ...

  8. jquery开发的数字相加游戏(你能玩几分)

    jquery开发的数字相加游戏,我在一轮中玩了632分(如下图),你能玩几分,哈哈... 我要试一试 下面贡献下这款“数字相加游戏”的开发过程. html部分: <div class=" ...

  9. JQuery变量数字相加的研究

    在 jquery中,一个变量和一个数字相加,期望得到1+2=3但是: eg: <input type="text" class="input_Num" i ...

随机推荐

  1. web项目的两个创建形式website和webapplication

    前言 在利用VS2010创建web项目的时候,会有两个选择.可以选择直接创建website网站,还可以选择使用 webapplication应用程序.刚刚接触web开发,看到这两个就疑惑了,既然是都可 ...

  2. ASP.NET母版与内容页相对路径的问题

    1. 图片问题 非常好解决 <img runat="server" src="~/images/ad468x60.gif" alt="" ...

  3. HTML与CSS入门——第三章 理解HTML和XHTML的关系

    知识点: 1.以HTML创建一个简单网页的方法 2.包含每个网页必须有的所有HTML标签的方法 3.用段落和换行组织页面的方法 4.用标题组织内容的方法 5.HTML.XML.XHTML和HTML5之 ...

  4. iOS开发 ~应用程序设计理念:视图控制器(UIViewController)、视图(UIView)

    应用程序设计理念:视图控制器(UIViewController).视图(UIView) 利用视图控制器(底层)管理视图(外观),一对一 1.视图的作用:负责显示的外观 2.视图控制器的作用:创建界面. ...

  5. OpenCV——人脸检测

    OpenCV支持的目标检测的方法: 利用样本的Haar特征进行的分类器训练,得到的级联boosted分类器(Cascade Classification) 1.加载级联分类器 CascadeClass ...

  6. android 利用重力感应监听 来电时翻转手机后静音。

       在CallNotifier.java中 加入如下代码: public void GetSensorManager(Context context) { sm = (SensorManager) ...

  7. Array类型(二)

    1.concat()方法可以基于当前数组中的所有项创建一个新数组. 先创建当前数组的一个副本,然后将接收到的参数添加到这个副本的末尾,最后返回新构建的数组. var colors = ["r ...

  8. Response 关于浏览器header的方法

    Response.AddHeader   Response.AddHeader使用实例 1.文件下载,指定默认名 Response.AddHeader("content-type" ...

  9. c++基础五个题(三)

    一.一个对象访问普通函数和虚函数的时候,哪一个更快? 访问普通函数更快,因为普通成员函数在编译阶段已经被确定,因此在访问时直接调用对应地址的函数,而虚函数在调用时,需要首先在虚函数表中查找虚函数所在的 ...

  10. Travel(HDU 5441 2015长春区域赛 带权并查集)

    Travel Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Total Su ...