Pereiti prie turinio

Rekomenduojami pranešimai

xGavau tokią užduotėlę ir nežinau, kaip ją spręsti. Galbūt nežinau kokios nors funkcijos ar pačio algoritmo. Sąlyga:

 

Parenkite programą, kuri sudėtų sveikuosius skaičius, sudarytus iš daug skaitmenų.

Pirmoje pradinių duomenų failo eilutėje nurodytas skaičių kiekis. Toliau kiekvienoje eilutėje įrašytas sveikasis skaičius, kurio skaitmenų skaičius ne mažesnis kaip 20 ir ne didesnis kaip 80. Prieš kiekvieną skaičių nurodyta, iš kelių skaitmenų jis yra sudarytas.

 

 

-------------------------------------------
Pradiniai duomenys                 		
-------------------------------------------
3                                  		
22 5126717910121751622546
29 88888888888888888888888888888
37 2525255125133485451578436833138834387837
-------------------------------------------
Rezultatai
-------------------------------------------
2525255125222374345594043632149474899271|
-------------------------------------------

 

#include <iostream>
#include <iomanip>
#include <fstream>
#include <string>
// #include <cmath>
using namespace std;

const char Dfailas[] = "Duom.txt";
const char Rfailas[] = "Rez.txt";

int main()
{
setlocale(LC_ALL, "Lithuanian");
int A[100];   int n;
string str[100] = {};
ifstream fd(Dfailas);
fd >> n;
for (int i = 0; i < n; i++) {
fd >> A[i] >> str[i];
}
fd.close();
...
...
...
return 0;
}

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Programėlė :)

#include <iostream>
#include <string>

using namespace std;

string getSum(string a, string b) {
   string result = "";
   int liek = 0;

   if(a.size() < b.size())
       a.insert(0, b.size() - a.size(), '0');
   else
       b.insert(0, a.size() - b.size(), '0');

   for(int i = a.size() - 1; i >= 0; --i) {
       liek += a[i] + b[i] - 2 * '0';

       result.push_back(liek % 10 + '0');

       liek /= 10;
   }

   while(liek) {
       result.push_back(liek % 10 + '0');
       liek /= 10;
   }

   reverse(result.begin(), result.end());

   return result;
}

int main() {
   int n, l;
   string a, sum;
   cin >> n;

   for(int i = 0; i < n; ++i) {
       if(!i) {
           cin >> l >> sum;
       } else {
           cin >> l >> a;
           sum = getSum(sum, a);
       }
   }

   cout << sum << '\n';

   return 0;
}

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

×
×
  • Pasirinkite naujai kuriamo turinio tipą...