0249 - PozitieX: Difference between revisions
Tita Marian (talk | contribs) No edit summary |
|||
Line 2: | Line 2: | ||
Se dă un număr natural '''X''' şi un şir cu '''n''' numere naturale distincte două câte două. Să se determine poziţia pe care s-ar afla numărul '''X''' în şirul ordonat crescător. | Se dă un număr natural '''X''' şi un şir cu '''n''' numere naturale distincte două câte două. Să se determine poziţia pe care s-ar afla numărul '''X''' în şirul ordonat crescător. | ||
== Date de intrare == | == Date de intrare == | ||
Fişierul de intrare ''' | Fişierul de intrare '''pozitiexin.txt''' conţine pe prima linie numerele '''X''' şi '''n'''. Urmează '''n''' numere naturale, dispuse pe mai multe linii, separate prin spaţii. | ||
== Date de ieșire == | == Date de ieșire == | ||
Fişierul de ieşire ''' | Fişierul de ieşire '''pozitiexout.txt''' va conţine pe prima linie numărul '''p''', reprezentând poziţia în şirul ordonat crescător a primului element din şirul dat. Dacă numărul '''X''' nu apare în şir, se va afişa mesajul '''NU EXISTA'''. | ||
În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse.", iar daca se indeplinesc se afiseaza mesajul "Datele de intrare corespund restricțiilor impuse." | |||
== Restricţii şi precizări == | == Restricţii şi precizări == | ||
* 1 ≤ '''n''' ⩽ 1.0000 | * 1 ≤ '''n''' ⩽ 1.0000 | ||
Line 10: | Line 11: | ||
== Exemplul 1 == | == Exemplul 1 == | ||
; | ; Intrare | ||
79 6 | |||
267 13 45 628 7 79 | |||
; | ; Iesire | ||
Datele de intrare corespund restrictilor impuse. | |||
4 | |||
== Exemplul 2 == | |||
; Intrare | |||
79 0 | |||
; Iesire | |||
Datele de intrare nu corespund restrictilor impuse. | |||
<br> | <br> | ||
== Rezolvare == | == Rezolvare == | ||
<syntaxhighlight lang="python" line> | <syntaxhighlight lang="python" line> | ||
def gaseste_pozitie(X, sir): | |||
sir.sort() | sir.sort() | ||
for i in range(len(sir)): | for i in range(len(sir)): | ||
Line 27: | Line 35: | ||
if __name__ == "__main__": | if __name__ == "__main__": | ||
# Citim X și n din fișierul de intrare | try: | ||
# Citim X și n din fișierul de intrare | |||
with open("pozitiexin.txt", "r") as f: | |||
X, n = map(int, f.readline().strip().split()) | |||
sir = list(map(int, f.read().split())) | |||
# Verificăm restricțiile impuse | |||
if 1 <= n <= 10000 and all(1 <= num <= 999999999 for num in sir) and 1 <= X <= 999999999: | |||
# Găsim poziția lui X în șir | |||
pozitie = gaseste_pozitie(X, sir) | |||
# Scriem rezultatul în fișierul de ieșire | |||
with open("pozitiexout.txt", "w") as f: | |||
# | if pozitie != -1: | ||
f.write(str(pozitie) + "\n") | |||
else: | |||
f.write("NU EXISTA\n") | |||
print("Datele de intrare corespund restricțiilor impuse.") | |||
else: | |||
# Dacă datele de intrare nu respectă restricțiile, afișăm mesaj de eroare în fișierul de ieșire | |||
with open("pozitiexout.txt", "w") as f: | |||
f.write("Date de intrare invalide\n") | |||
except Exception as e: | |||
# Dacă apar erori neprevăzute, afișăm mesajul de eroare în fișierul de ieșire | |||
with open("pozitiexout.txt", "w") as f: | |||
f.write(f"O eroare a apărut: {str(e)}\n") | |||
</syntaxhighlight> | </syntaxhighlight> | ||
==Explicație== | ==Explicație== | ||
Şirul sortat este '''7 13 45 79 267 628'''. În acest şir, valoarea '''79''' se află pe poziţia a '''4'''-a. | Şirul sortat este '''7 13 45 79 267 628'''. În acest şir, valoarea '''79''' se află pe poziţia a '''4'''-a. |
Revision as of 19:25, 15 December 2023
Cerinţa
Se dă un număr natural X şi un şir cu n numere naturale distincte două câte două. Să se determine poziţia pe care s-ar afla numărul X în şirul ordonat crescător.
Date de intrare
Fişierul de intrare pozitiexin.txt conţine pe prima linie numerele X şi n. Urmează n numere naturale, dispuse pe mai multe linii, separate prin spaţii.
Date de ieșire
Fişierul de ieşire pozitiexout.txt va conţine pe prima linie numărul p, reprezentând poziţia în şirul ordonat crescător a primului element din şirul dat. Dacă numărul X nu apare în şir, se va afişa mesajul NU EXISTA. În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse.", iar daca se indeplinesc se afiseaza mesajul "Datele de intrare corespund restricțiilor impuse."
Restricţii şi precizări
- 1 ≤ n ⩽ 1.0000
- X şi elementele şirului vor avea cel mult 9 cifre
Exemplul 1
- Intrare
79 6 267 13 45 628 7 79
- Iesire
Datele de intrare corespund restrictilor impuse. 4
Exemplul 2
- Intrare
79 0
- Iesire
Datele de intrare nu corespund restrictilor impuse.
Rezolvare
<syntaxhighlight lang="python" line> def gaseste_pozitie(X, sir):
sir.sort() for i in range(len(sir)): if sir[i] == X: return i + 1 # Returnăm poziția (pornind de la 1) return -1 # Dacă nu găsim X în șir, returnăm -1
if __name__ == "__main__":
try: # Citim X și n din fișierul de intrare with open("pozitiexin.txt", "r") as f: X, n = map(int, f.readline().strip().split()) sir = list(map(int, f.read().split()))
# Verificăm restricțiile impuse if 1 <= n <= 10000 and all(1 <= num <= 999999999 for num in sir) and 1 <= X <= 999999999: # Găsim poziția lui X în șir pozitie = gaseste_pozitie(X, sir)
# Scriem rezultatul în fișierul de ieșire with open("pozitiexout.txt", "w") as f: if pozitie != -1: f.write(str(pozitie) + "\n") else: f.write("NU EXISTA\n") print("Datele de intrare corespund restricțiilor impuse.") else: # Dacă datele de intrare nu respectă restricțiile, afișăm mesaj de eroare în fișierul de ieșire with open("pozitiexout.txt", "w") as f: f.write("Date de intrare invalide\n") except Exception as e: # Dacă apar erori neprevăzute, afișăm mesajul de eroare în fișierul de ieșire with open("pozitiexout.txt", "w") as f: f.write(f"O eroare a apărut: {str(e)}\n")
</syntaxhighlight>
Explicație
Şirul sortat este 7 13 45 79 267 628. În acest şir, valoarea 79 se află pe poziţia a 4-a.