首页 > 其他分享 >Problem E: 新奇的加法运算

Problem E: 新奇的加法运算

时间:2023-05-25 17:36:40浏览次数:43  
标签:10 newInt int sum ++ xx 新奇 加法 Problem


Home

Web Board

ProblemSet

Standing

Status

Statistics


Problem E: 新奇的加法运算


Time Limit: 1 Sec   Memory Limit: 128 MB

Submit: 1117  

Solved: 685

[Submit][Status][Web Board]


Description



定义类newInt,包括:

1. int类型的数据成员。

2. 重载运算符“+”。计算规则为:将A、B对应位置上的数字相加,只保留个位数作为结果的对应位置上的数字。比如:876 + 543 = 319。注意:该运算不改变两个操作数的值。

3. 重载输入和输出运算符,用于输入和输出对象的属性值。

4. 无参构造函数和带参构造函数。



Input



第1行N>0,表示测试用例数量。

每个测试用例包括2个非负整数,用空格隔开。



Output



见样例。



Sample Input



4876 543999 99999 1999199 88



Sample Output



876 + 543 = 319999 + 9999 = 98889 + 1999 = 1998199 + 88 = 177



HINT



 不能使用string、char等字符或字符串类型。



Append Code



append.cc,


[ Submit][Status][Web Board]


한국어<  中文 فارسی English ไทย All Copyright Reserved 2010-2011 SDUSTOJ TEAM
GPL2.0 2003-2011 HUSTOJ Project TEAM
Anything about the Problems, Please Contact Admin:admin


#include <iostream>
    #include <cstdio>
    using namespace std;
  
    class newInt
    {
    private:
        int x;
    public:
        newInt():x(0){}
        newInt(int xx):x(xx){}
        ~newInt(){}
        friend newInt operator + (const newInt &m,const newInt &n)
        {
            newInt t;
            int arr[100];
            int arr2[100];
            int arr3[100];
            for(int i=0;i<100;i++)
                arr[i]=0;
            for(int i=0;i<100;i++)
                arr2[i]=0;
                for(int i=0;i<100;i++)
                arr3[i]=0;
  
            int flag=0;
            int a=0;
            int b =0;
            int xx = m.x;
            int yy = n.x;
            while(xx>0)
            {
                arr[a++] = xx%10;
                xx =xx/10;
                flag++;
            }
            int flag2=0;
            while(yy>0)
            {
                arr2[b++] = yy%10;
                yy /= 10;
                flag2++;
            }
            flag = max(flag,flag2);
            for(int i=0;i<flag;i++)
            {
                if(arr[i]+arr2[i]<10)
                    arr3[i] = arr[i]+arr2[i];
                    else arr3[i] = arr[i]+arr2[i]-10;
            }
            int sum=0;
            for(int i=flag;i>=0;i--)
            {
                sum=10*sum;
                sum += arr3[i];
            }
            t.x= sum;
            return t.x;
        }
       friend ostream &operator << (ostream &os,newInt &t)
        {
            os<<t.x;
            return os;
        }
       friend istream &operator >>(istream &is,newInt &t)
        {
            is>>t.x;
            return is;
        }
    };
int main()
{
    int cases;
    newInt a, b, c;
    cin>>cases;
    for (int i = 0; i < cases; i++)
    {
        cin>>a>>b;
        c = a + b;
        cout<<a<<" + "<<b<<" = "<<c<<endl;
    }
    return 0;
}



标签:10,newInt,int,sum,++,xx,新奇,加法,Problem
From: https://blog.51cto.com/u_16129621/6350310

相关文章

  • Problem A: 类的初体验
    HomeWebBoardProblemSetStandingStatusStatisticsProblemA:类的初体验TimeLimit:1Sec  MemoryLimit:128MBSubmit:723  Solved:661[Submit][Status][WebBoard]Description定义一个类Data,只有一个double类型的属性和如下3个方法:1.  voi......
  • Problem D: 平面上的点——Point类 (IV)
    ProblemD:平面上的点——Point类(IV)TimeLimit:1Sec  MemoryLimit:4MBSubmit:5400  Solved:3167[Submit][Status][WebBoard]Description在数学上,平面直角坐标系上的点用X轴和Y轴上的两个坐标值唯一确定。现在我们封装一个“Point类”来实现平面上......
  • Problem E: 判断两个圆之间的关系
    HomeWebBoardProblemSetStandingStatusStatisticsProblemE:判断两个圆之间的关系TimeLimit:1Sec  MemoryLimit:128MBSubmit:1107  Solved:925[Submit][Status][WebBoard]Description定义Point类,包括double类型的两个属性,分别表示二维空间......
  • Problem B: 时间类的成员读写
    HomeWebBoardProblemSetStandingStatusStatisticsProblemB:时间类的成员读写TimeLimit:4Sec  MemoryLimit:128MBSubmit:3080  Solved:2668[Submit][Status][WebBoard]Description封装一个时间类Time,用于时间处理的相关功能,支持以下操......
  • Problem F: 平面上的点和线——Point类、Line类 (VI)
    HomeWebBoardProblemSetStandingStatusStatisticsProblemF:平面上的点和线——Point类、Line类(VI)TimeLimit:1Sec  MemoryLimit:128MBSubmit:4350  Solved:2006[Submit][Status][WebBoard]Description在数学上,平面直角坐标系上的点......
  • Problem E: 编写函数:Swap (I) (Append Code)
    ProblemE:编写函数:Swap(I)(AppendCode)TimeLimit:1Sec  MemoryLimit:16MBSubmit:7937  Solved:5693[Submit][Status][WebBoard]Description编写用来交换两个数的函数,使得“AppendCode”中的main()函数能正确运行。---------------------------......
  • 一元多项式的乘法与加法运算
    设计函数分别求两个一元多项式的乘积与和。输入格式:输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数)。数字间以空格分隔。输出格式:00。输入样例:434-5261-203520-7431输出样例:1......
  • The 3n + 1 problem
    ProblemsinComputerScienceareoftenclassifiedasbelongingtoacertainclassofproblems(e.g.,NP,Unsolvable,Recursive).Inthisproblemyouwillbeanalyzingapropertyofanalgorithmwhoseclassificationisnotknownforallpossibleinputs. Co......
  • 每日一题 力扣 1377 https://leetcode.cn/problems/frog-position-after-t-seconds/
    力扣1377https://leetcode.cn/problems/frog-position-after-t-seconds/这道题目用dp去做,构建邻接矩阵,做的时候需要注意题目条件,如果青蛙跳不动了,这个概率就保持不变了一般跳青蛙,很容易想到dp核心代码如下publicdoublefrogPosition(ipublicdoublefrogPosition(intn,......
  • AI的一致性问题(AI Alignment Problem)
    AI的一致性问题 (图片来源:维基百科,Kismetrobot。)人工智慧(AI)系统可以应用到很多方面,帮人类解决很多问题。但不论AI的原始目的是什么,万一AI发展出自己的功能或意识,做出预料之外的事,这可能会造成很多严重的后果,例如在很多电影里面变坏的机器人,试图控制人类的电脑等等。所以如何......