0247 - CifreOrd1: Difference between revisions

From Bitnami MediaWiki
Pagină nouă: Sursa: [https://www.pbinfo.ro/probleme/247/cifreord1 - CifreOrd1] ---- == Cerinţa == Se dau mai multe numere naturale, fiecare cu cel mult '''9''' cifre. Să se afişeze, în ordine descrescătoare, toate cifrele care apar în numerele date. == Date de intrare == Fişierul de intrare '''cifreord1.in''' conţine cel mult '''10.000''' numere naturale, dispuse pe mai multe linii. == Date de ieșire == Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt cor...
 
mNo edit summary
Line 42: Line 42:
         counter[i].append(i)
         counter[i].append(i)
     f = open("cifreord1.out", "w")
     f = open("cifreord1.out", "w")
     k = 0
     elemente_pe_linie = 0
     for i in range(9, -1, -1):
     for i in range(9, -1, -1):
         y = int(counter[i][0])
         numar_repetitie_cifra = int(counter[i][0])
         for j in range(y):
         for j in range(numar_repetitie_cifra):
             k += 1
             elemente_pe_linie += 1
             if k % 20 == 0:
             if elemente_pe_linie % 20 == 0:
                 f.write("\n")
                 f.write("\n")
             else:
             else:
Line 60: Line 60:
         for line in lines:
         for line in lines:
             for c in line.split():
             for c in line.split():
                 if c.isdigit() == True:
                 if c.isdigit() is True:
                     vector.append(int(c))
                     vector.append(int(c))
     if len(vector) > 10000:
     if len(vector) > 10000:
Line 66: Line 66:
         exit()
         exit()
     for x in vector:
     for x in vector:
         if x < 0 or x >= 1000000:
         if x < 0 and x >= 1000000:
             print("Datele nu sunt comform restricțiilor impuse.")
             print("Datele nu sunt comform restricțiilor impuse.")
             exit()
             exit()
Line 76: Line 76:
     vector = conform_restrictiilor()
     vector = conform_restrictiilor()
     numere(vector)
     numere(vector)




</syntaxhighlight>
</syntaxhighlight>

Revision as of 16:52, 19 March 2023

Sursa: - CifreOrd1


Cerinţa

Se dau mai multe numere naturale, fiecare cu cel mult 9 cifre. Să se afişeze, în ordine descrescătoare, toate cifrele care apar în numerele date.

Date de intrare

Fişierul de intrare cifreord1.in conţine cel mult 10.000 numere naturale, dispuse pe mai multe linii.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt corecte.", iar apoi in fişierul de ieşire cifreord1.out va conţine cifrele determinate, ordonate descrescător, câte 20 pe o linie, valorile de pe fiecare linie fiind separate prin spaţii. Ultima linie a fişierului poate conţine mai puţin de 20 de cifre. În caz contrar, se va afișa pe ecran: "Datele nu sunt comform restricțiilor impuse.".

Exemple

Exemplul 1

cifreord1.in
301941 81912 83392
776996 431446
Ieșire
Datele sunt corecte.
cifreord1.out
9 9 9 9 9 8 8 7 7 6 6 6 4 4 4 4 3 3 3 3
2 2 1 1 1 1 1 0

Exemplul 2

nrlipsa.in
100 1001 900
Ieșire
Datele sunt corecte.
nrlipsa.out
9 1 1 1 0 0 0 0 0 0

Exemplul 3

nrlipsa.in
489127491479 4198749127591 100
Ieșire
Datele nu sunt comform restricțiilor impuse.


Rezolvare

<syntaxhighlight lang="python" line>

  1. 0247 CifreOrd1

def numere(vector):

   vector = str(vector)
   counter = list()
   for i in range(10):
       counter.append([vector.count(str(i))])
       counter[i].append(i)
   f = open("cifreord1.out", "w")
   elemente_pe_linie = 0
   for i in range(9, -1, -1):
       numar_repetitie_cifra = int(counter[i][0])
       for j in range(numar_repetitie_cifra):
           elemente_pe_linie += 1
           if elemente_pe_linie % 20 == 0:
               f.write("\n")
           else:
               f.write(str(counter[i][1]))
               f.write(" ")


def conform_restrictiilor():

   vector = list()
   with open('cifreord1.in') as f:
       lines = f.readlines()
       for line in lines:
           for c in line.split():
               if c.isdigit() is True:
                   vector.append(int(c))
   if len(vector) > 10000:
       print("Datele nu sunt comform restricțiilor impuse.")
       exit()
   for x in vector:
       if x < 0 and x >= 1000000:
           print("Datele nu sunt comform restricțiilor impuse.")
           exit()
   print("Datele sunt corecte.")
   return vector


if __name__ == '__main__':

   vector = conform_restrictiilor()
   numere(vector)


</syntaxhighlight>