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

#3902 SortSum Vă rog mult de tot!
Scrie un program care citind un șir de numere naturale afișează numerele citite ordonate crescător după suma cifrelor lor, iar dacă suma cifrelor este egală, descrescător după valoarea lor.
Date de intrare: Fișierul de intrare sortsum.in conține pe prima linie numere naturale separate prin spații.
Date de ieșire : Fișierul de ieșire sortsum.out va conține pe prima linie numerele ordonate conform cerinței.
Restricții și precizări: în fișier vor fi mai puțin de 1.000.000 de numere numerele din fișierul de intrare vor fi mai mici decât 10.000.000
Exemplu:
sortsum.in
102 60 51 600 21 3
sortsum.out
102 21 3 600 60 51​

Răspunsuri la întrebare

Răspuns de Sergetec
5

Salut!

Ai rezolvarea in C++ mai jos

#include <fstream>

using namespace std;

ifstream cin("sortsum.in");

ofstream cout("sortsum.out");

const int N = 1e7;

int a[N/10 + 2], x, n;

int sum(int n)

{

 int s = 0;

 while (n)

 {

   s += n % 10;

   n /= 10;

 }

 return s;

}

int main()

{

 while (cin >> n)

 {

   a[x++] = sum(n) * N + N - n;

 }

 sort(a, a + x);

 for (int i = 0; i < x; ++i)

 {

   cout << N - a[i] % N << " ";

 }

 cin.close();

 cout.close();

 return 0;

}


allfordreams: Mulțumesc mult! ❤
Sergetec: Cu mare placere
Am observat acum ca am uitat sa adaug #include acolo sus, sa incluzi tu pentru 100p
Sergetec: algorithm
allfordreams: E ok, am adăugat eu. Doar ca îmi da eroare din cauza sort ului...
Sergetec: Da, pai in loc de functia sort() poti folosi un algoritm de sortare mai rapid, nu stiu daca cel cu 2 for-uri intra in limita de timp din pacate
Sergetec: Dar cu functia sort iti va da 100p
allfordreams: Da, probabil de asta îmi da eroare. Mulțumesc frumos!
Alte întrebări interesante