3116 高精度练习之加法——http://codevs.cn/problem/3116/

第一部分:题目

题目描述 Description

给出两个正整数A和B,计算A+B的值。保证A和B的位数不超过500位。

输入描述 Input Description

读入两个用空格隔开的正整数

输出描述 Output Description

输出A+B的值

样例输入 Sample Input

3 12

样例输出 Sample Output

15

数据范围及提示 Data Size & Hint

两个正整数的位数不超过500位

第二部分:思路

由于数值比较大,所以用字符串形式接收。因为相加是从个位开始,所以可以从数组最后开始(这样需要判断哪个数长,稍微麻烦点)或者先把数组倒置在进行计算。这里使用的是后者。当两个数的长度不一样时需要把长的那个继续计算。在相加的过程中,需要判断是否需要进位,这里的flag变量其实就起到这个作用。

第三部分:代码

#include<stdio.h>
#include<string.h>
void repai(char s[500],int len)//把数组倒置
{
    int i,j=len-1;
    char t;
    for(i=0;i<j;i++)
    {
        j=len-i-1;//相当于以中点对折。
        t=s[i];
        s[i]=s[j];
        s[j]=t;
    }
}
int main()
{
    char a[500],b[500];//接收数a、b
    int result[501],length=0,alen,blen;
    scanf("%s %s",a,b);
    alen=strlen(a);//数组a、b长度
    blen=strlen(b);
    int i,j,flag=0;
    repai(a,alen);//倒置
    repai(b,blen);
    int t;
    for(i=0;i<alen&&i<blen;i++)//从个位开始相加
    {
        t=a[i]-‘0‘+b[i]-‘0‘+flag;
        if(t>9)//判断是否需要进位
        {
            t-=10;
            flag=1;
        }
        else//这里稍微注意一下,当前不需要进位时置为0
        {
            flag=0;
        }
        result[length++]=t;
    }
    while(i<alen)
    {
        t=a[i]-‘0‘+flag;
        if(t>9)
        {
            t-=10;
            flag=1;
        }
        else
        {
            flag=0;
        }
        result[length++]=t;
        i++;
    }
    while(i<blen)
    {
        t=b[i]-‘0‘+flag;
        if(t>9)
        {
            t-=10;
            flag=1;
        }
        else
        {
            flag=0;
        }
        result[length++]=t;
        i++;
    }
    if(flag)
    {
        result[length++]=1;
    }
    for(i=length-1;i>=0;i--)
    {
        printf("%d",result[i]);
    }
    printf("\n");
    return 0;
}
时间: 2024-11-05 06:26:02

3116 高精度练习之加法——http://codevs.cn/problem/3116/的相关文章

3115 高精度练习之减法——http://codevs.cn/problem/3115/

第一部分:题目 题目描述 Description 给出两个正整数A和B,计算A-B的值.保证A和B的位数不超过500位. 输入描述 Input Description 读入两个用空格隔开的正整数 输出描述 Output Description 输出A-B的值 样例输入 Sample Input 3 12 样例输出 Sample Output -9 数据范围及提示 Data Size & Hint 两个正整数的位数不超过500位 第二部分:思路 具体看代码注释 第三部分:代码 #include<

3116 高精度练习之加法

3116 高精度练习之加法 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 给出两个正整数A和B,计算A+B的值.保证A和B的位数不超过500位. 输入描述 Input Description 读入两个用空格隔开的正整数 输出描述 Output Description 输出A+B的值 样例输入 Sample Input 3 12 样例输出 Sample Output 15 数据范围及提示 Data Size & Hint

codevs http://www.codevs.cn/problem/?problemset_id=1 循环、递归、stl复习题

12.10高一练习题 1.要求: 这周回顾复习的内容是循环.递归.stl. 不要因为题目简单就放弃不做,现在就是练习基础. 2.练习题: (1)循环   题目解析与代码见随笔分类  NOI题库 http://noi.openjudge.cn/ch0106/    10-15题 http://noi.openjudge.cn/ch0105/     37-45题 http://noi.openjudge.cn/ch0107/     28-35题 (2)递归   题目解析与代码见随笔分类 递归 h

wiki oi 3116 高精度练习之加法

题目描述 Description 给出两个正整数A和B,计算A+B的值.保证A和B的位数不超过500位. 输入描述 Input Description 读入两个用空格隔开的正整数 输出描述 Output Description 输出A+B的值 样例输入 Sample Input 3 12 样例输出 Sample Output 15 数据范围及提示 Data Size & Hint 两个正整数的位数不超过500位 分析:和减法一样,去掉了两个数的大小比较,发现没必要,还有发现不用判断cc大于10么

1098 均分纸牌 ——http://codevs.cn/problem/1098/

第一部分:题目 题目描述 Description 有 N 堆纸牌,编号分别为 1,2,…, N.每堆上有若干张,但纸牌总数必为 N 的倍数.可以在任一堆上取若于张纸牌,然后移动. 移牌规则为:在编号为 1 堆上取的纸牌,只能移到编号为 2 的堆上:在编号为 N 的堆上取的纸牌,只能移到编号为 N-1 的堆上:其他堆上取的纸牌,可以移到相邻左边或右边的堆上. 现在要求找出一种移动方法,用最少的移动次数使每堆上纸牌数都一样多. 例如 N=4,4 堆纸牌数分别为: ① 9 ② 8 ③ 17 ④ 6 移

3143 二叉树的序遍历——http://codevs.cn/problem/3143/

第一部分:题目 题目描述 Description 求一棵二叉树的前序遍历,中序遍历和后序遍历 输入描述 Input Description 第一行一个整数n,表示这棵树的节点个数. 接下来n行每行2个整数L和R.第i行的两个整数Li和Ri代表编号为i的节点的左儿子编号和右儿子编号. 输出描述 Output Description 输出一共三行,分别为前序遍历,中序遍历和后序遍历.编号之间用空格隔开. 样例输入 Sample Input 5 2 3 4 5 0 0 0 0 0 0 样例输出 Sam

3145 汉诺塔游戏——http://codevs.cn/problem/3145/

第一部分:题目 题目描述 Description 汉诺塔问题(又称为河内塔问题),是一个大家熟知的问题.在A,B,C三根柱子上,有n个不同大小的圆盘(假设半径分别为1-n吧),一开始他们都叠在我A上(如图所示),你的目标是在最少的合法移动步数内将所有盘子从A塔移动到C塔. 游戏中的每一步规则如下: 1. 每一步只允许移动一个盘子(从一根柱子最上方到另一个柱子的最上方) 2. 移动的过程中,你必须保证大的盘子不能在小的盘子上方(小的可以放在大的上面,最大盘子下面不能有任何其他大小的盘子) 如对于n

1842 递归第一次——http://codevs.cn/problem/1842/

第一部分:题目 题目描述 Description 同学们在做题时常遇到这种函数 f(x)=5 (x>=0) f(x)=f(x+1)+f(x+2)+1 (x<0) 下面就以这个函数为题做一个递归程序吧 输入描述 Input Description 一个数表示f(x)中x值 大家注意就一个数,前面代表样例编号 输出描述 Output Description 一个数表示值 大家注意就一个数,前面代表样例编号 样例输入 Sample Input 样例一:0 样例二:-5 样例输出 Sample Out

3038 3n+1问题——http://codevs.cn/problem/3038/

第一部分:题目 题目描述 Description 3n+1问题是一个简单有趣而又没有解决的数学问题.这个问题是由L. Collatz在1937年提出的.克拉兹问题(Collatz problem)也被叫做hailstone问题.3n+1问题.Hasse算法问题.Kakutani算法问题.Thwaites猜想或者Ulam问题. 问题如下: (1)输入一个正整数n: (2)如果n=1则结束: (3)如果n是奇数,则n变为3n+1,否则n变为n/2: (4)转入第(2)步. 克拉兹问题的特殊之处在于: