Informatică, întrebare adresată de matei772006oww396, 8 ani în urmă

Un celebru (sperăm) rezolvitor de pe acest site își va lua un calculator nou dacă intră la liceul la care dorește să intre. Dar momentan rămâne pe calculatorul său rezolvând probleme. Una dintre ele era foarte simplă și constă în adunarea/scăderea a două numere naturale.

Cerința
Se dau 2 numere naturale. Calculați suma / diferenţa lor.

Date de intrare
Fișierul de intrare calcmare.in conține pe prima linie numărul a, pe a doua linie numărul b, iar pe a treia linie un semn + sau - care arată dacă numerele trebuie adunate / scăzute.

Date de ieșire
Fișierul de ieșire calcmare.out va conține pe prima linie numărul R, reprezentând rezultatul determinat.

Restricții și precizări
1 ≤ nr. cifre număr ≤ 1000.
Pentru 50% din punctaj semnul va fi + , iar pentru restul de 50%, semnul -.
Pentru 20% din punctaj nr. cifre număr ≤ 15.
Se garantează că a≥b pentru scăderi.


boiustef: frumoasa problema... care costa mai multe puncte.. :))) , glumesc

Răspunsuri la întrebare

Răspuns de varunax424
1

#include <bits/stdc++.h>

using namespace std;

int main()

{

   ifstream fin("calcmare.in");

   ofstream fout("calcmare.out");

   long long a,b;

   char c;

   fin >> a >> b >> c;

   if(c=='+')

       fout << a+b;

   else if(c=='-')

       fout << a-b;

}


boiustef: Varunax424, ai testat codul pe pbinfo?
#2266 CalcMare
boiustef: numerele pot avea 1000 de cifre, dar long long numai 20
Răspuns de boiustef
2

Răspuns:

#include <iostream>

#include <fstream>

#include <cstring>

using namespace std;

ifstream f("calcmare.in");

ofstream g("calcmare.out");

char op,s1[1003],s2[1003];

short a[1003],b[1003],c[1003], t,r,i,lena,lenb,lenc,cif,dim;

int main()

{

   f.getline(s1,1003);

   f.getline(s2,1003);

   f >> op;

   lena=strlen(s1);

   lenb=strlen(s2);

   dim=max(lena,lenb);

   for (i=0; i<lena; i++)

   {

       a[i]=s1[lena-1-i]-'0';

   }

   for (i=0; i<lenb; i++)

   {

       b[i]=s2[lenb-1-i]-'0';

   }

   if (op=='+')

   {

      for (i=0; i<dim; i++)

      {

          r=a[i]+b[i]+t;

          c[i]=r%10;

          t=r/10;

      }

      if (t) c[dim++]=t;

      lenc=dim;

   }

   else

   {

       for (i=0; i<lena; i++)

       {

           if (a[i]>=b[i]) c[i]=a[i]-b[i];

           else

           {

               t=i+1;

               while (a[t]==0 && t<lena)  a[t]=9;

               --a[t];

               c[i]=10+a[i]-b[i];

           }

       }

       lenc=lena;

       while (c[lenc-1]==0) --lenc;

   }

   for (i=lenc-1; i>=0; i--)

       g << c[i];

   return 0;

}

Explicație:

acest cod a luat acum 90 puncte pe pbinfo

DAca treci si celalalt test gresit esti super... Succese

Alte întrebări interesante