0247 - CifreOrd1: Difference between revisions
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") | ||
elemente_pe_linie = 0 | |||
for i in range(9, -1, -1): | for i in range(9, -1, -1): | ||
numar_repetitie_cifra = int(counter[i][0]) | |||
for j in range( | for j in range(numar_repetitie_cifra): | ||
elemente_pe_linie += 1 | |||
if | 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() | 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 | 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>
- 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>