👤

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 numerenumerele 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



Explicație

Numerele 102, 21 și 3 au suma cifrelor 3, iar 600, 60, 51 au suma cifrelor 6. Mai întâi se afișează numerele ce au suma cifrelor cea mai mică (3), în ordine descrescătoare, apoi cele care au suma cifrelor 6, tot în ordine descrescătoare


Răspuns :

#include <iostream>

#include <fstream>

#include <cstring>

using namespace std;

int sum_cif(int x) {

int sum = 0;

while (x != 0) {

sum += x % 10;

x /= 10;

}

return sum;

}

int main() {

ifstream fin("sortsum.in");

ofstream fout("sortsum.out");

int sir[1000], sir_sum_cif[1000], n = 0;

while (fin >> sir[n]) {

sir_sum_cif[n] = sum_cif(sir[n]);

n++;

}

for (int i = 0; i < n - 1; i++) {

for (int j = i + 1; j < n; j++) {

if (sir_sum_cif[i] > sir_sum_cif[j]) {

swap(sir_sum_cif[i], sir_sum_cif[j]);

swap(sir[i], sir[j]);

}

if (sir_sum_cif[i] == sir_sum_cif[j] && sir[i] < sir[j]) {

swap(sir_sum_cif[i], sir_sum_cif[j]);

swap(sir[i], sir[j]);

}

}

}

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

fout << sir[i] << " ";

return 0;

}