0071 - Reducere: Difference between revisions

From Bitnami MediaWiki
Flaviu (talk | contribs)
No edit summary
Flaviu (talk | contribs)
No edit summary
 
(2 intermediate revisions by the same user not shown)
Line 22: Line 22:
* elementele vectorilor A, B sunt numere naturale din intervalul [1,10000]
* elementele vectorilor A, B sunt numere naturale din intervalul [1,10000]
0 < T ≤ 10
0 < T ≤ 10
== Exemplu ==
== Exemplu 1 ==
; Intrare
; Intrare
: 2
: 2
Line 38: Line 38:
: 0
: 0


== Exemplu ==
== Exemplu 2 ==
; Intrare
; Intrare
: 2
: 2
: 12
: 1001
: 7 3 4 1 6 4 6 9 7 1 8 7
: 7 3 4 1 6 4 6 9 7 1 8 7
: 4
: 4
Line 51: Line 51:
; Ieșire
; Ieșire
: Datele nu corespund restricțiilor impuse.
: Datele nu corespund restricțiilor impuse.
: 2
 
: 3
== Rezolvare ==  
== Rezolvare ==  
=== Rezolvare ver. 1 ===
=== Rezolvare ver. 1 ===
Line 58: Line 57:
# 0071 - Reducere
# 0071 - Reducere


def citeste_date_intrare():
def se_poate_reduca_la_B(A, B):
     n = int(input())
    i = j = 0
     a = list(map(int, input().split()))
     n = len(A)
     m = int(input())
     m = len(B)
    b = list(map(int, input().split()))
     while i < n and j < m:
     return a, b
        if A[i] == B[j]:
            i += 1
            j += 1
        else:
            s = A[i]
            i += 1
            while i < n and s < B[j]:
                s += A[i]
                i += 1
            if s != B[j]:
                return 0
            j += 1
     return j == m


def valideaza_datele_intrare(a, b):
def validare(n, A, m, B):
     if not(0 < len(a) < 1001 and 0 < len(b) < 1001):
     if not(1 <= n <= 1000) or not(1 <= m <= 1000):
         return False
         return False
     if not(all(1 <= x <= 10000 for x in a) and all(1 <= x <= 10000 for x in b)):
     if not all(1 <= a <= 10000 for a in A) or not all(1 <= b <= 10000 for b in B):
         return False
         return False
     return True
     return True


def se_poate_reduce(a, b):
if __name__ == "__main__":
     i, j = 0, 0
    T = int(input())
    while i < len(a) and j < len(b):
     if T <= 0 or T > 10:
         s = a[i]
        print("Datele nu corespund restricțiilor impuse.")
         i += 1
    else:
        while i < len(a) and s < b[j]:
         print("Datele sunt introduse corect.")
             s += a[i]
         for i in range(T):
             i += 1
             n = int(input())
        if s != b[j]:
             A = list(map(int, input().split()))
            return False
            m = int(input())
        j += 1
            B = list(map(int, input().split()))
    return j == len(b)
             if not validare(n, A, m, B):
 
                 print("Datele nu corespund restricțiilor impuse.")
if __name__ == '__main__':
    t = int(input())
    for _ in range(t):
        a, b = citeste_date_intrare()
        if valideaza_datele_intrare(a, b):
             if se_poate_reduce(a, b):
                 print("Datele sunt introduse corect.")
                print(1)
             else:
             else:
                 print("Datele sunt introduse corect.")
                 print(se_poate_reduca_la_B(A, B))
                print(0)
        else:
            print("Datele nu corespund restricțiilor impuse.")
 


</syntaxhighlight>
</syntaxhighlight>
== Explicatie Rezolvare ==
== Explicatie Rezolvare ==


Funcția citeste_date_intrare() citește cele două tablouri A și B din intrare și le returnează ca o pereche de liste. Funcția valideaza_datele_intrare(a, b) verifică dacă cele două liste respectă constrângerile impuse de problemă și returnează True dacă da și False altfel. Funcția se_poate_reduce(a, b) verifică dacă tabloul A se poate reduce la tabloul B și returnează True dacă da și False altfel.
validate_data(a, b): Această funcție primește ca parametri două liste, a și b, reprezentând cele două tablouri. Funcția validează dacă datele introduse respectă restricțiile problemei, adică dacă dimensiunile celor două tablouri sunt între 1 și 1000 și dacă toate elementele tablourilor sunt numere naturale între 1 și 10000. Dacă datele sunt valide, funcția returnează True, în caz contrar returnează False.
 
reduce(a, b): Această funcție primește ca parametri două liste, a și b, reprezentând cele două tablouri. Funcția verifică dacă tabloul a se poate reduce la tabloul b. În acest scop, parcurge fiecare element al tabloului b și caută în tabloul a o secvență de elemente consecutive aflate pe poziții consecutive în tabloul a, a cărei sumă să fie egală cu elementul curent din tabloul b. Dacă găsește o astfel de secvență, o elimină din tabloul a și trece la următorul element din tabloul b. Dacă nu găsește o astfel de secvență, funcția returnează False. Dacă se parcurge cu succes întregul tablou b și toate elementele sale au fost găsite în tabloul a, funcția returnează True.


În funcția principală (if __name__ == '__main__':) se citește numărul de seturi de date de test t, apoi se parcurg t iterații pentru a procesa fiecare set de date. Se citesc cele două tablouri, se validează și se verifică dacă A se poate reduce la B și se afișează rezultatul.
main(): Această funcție este funcția principală a programului. Ea citeste datele de intrare din consolă, apoi validează datele folosind funcția validate_data. Dacă datele sunt valide, se parcurg cele t teste și pentru fiecare test se citesc cele două tablouri și se apelează funcția reduce pentru a verifica dacă primul tablou se poate reduce la cel de-al doilea. Rezultatul verificării se afișează în consolă. Dacă datele nu sunt valide, se afișează un mesaj corespunzător.

Latest revision as of 20:14, 14 May 2023

Sursa: 0071 - Reducere


Cerinţa[edit | edit source]

Se consideră două tablouri unidimensionale A și B cu elemente numere naturale din intervalul [1,10000]. Spunem că tabloul A se poate reduce la tabloul B dacă există o împărțire a tabloului A în secvențe disjuncte de elemente aflate pe poziţii consecutive în tabloul A astfel încât prin înlocuirea secvențelor cu suma elementelor din secvență să se obţină, în ordine, elementele tabloului B. Se dau două tablouri A și B. Să se verifice dacă tabloul A se poate reduce la tabloul B.

Programul va citi mai multe seturi de date, fiecare constând în doi vectori A, B și va afișa pentru fiecare set de date dacă tabloul A se poate reduce la tabloul B.

Date de intrare[edit | edit source]

Programul citește un număr natural T, reprezentând numărul de seturi de date de test care urmează. Urmează T seturi de date, descrise astfel:

  • se citește n
  • se citesc n valori, reprezentând elementele tabloului A
  • se citește m
  • se citesc m valori, reprezentând elementele tabloului B

Date de ieșire[edit | edit source]

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele sunt introduse corect.", apoi pe un rând nou afișează pentru fiecare dintre cele T teste, pe câte o linie a ecranului valoare 1, dacă tabloul A se poate reduce la tabloul B, reprezentând valoarea cerută. În cazul contrar, se va afișa pe ecran: "Datele nu corespund restricțiilor impuse.".

Restricţii şi precizări[edit | edit source]

  • 0 < n, m < 1001
  • elementele vectorilor A, B sunt numere naturale din intervalul [1,10000]

0 < T ≤ 10

Exemplu 1[edit | edit source]

Intrare
2
12
7 3 4 1 6 4 6 9 7 1 8 7
4
14 7 26 16
5
1 4 2 2 3
3
5 3 4
Ieșire
Datele sunt introduse corect.
1
0

Exemplu 2[edit | edit source]

Intrare
2
1001
7 3 4 1 6 4 6 9 7 1 8 7
4
14 7 26 16
5
1 4 2 2 3
3
5 3 4
Ieșire
Datele nu corespund restricțiilor impuse.

Rezolvare[edit | edit source]

Rezolvare ver. 1[edit | edit source]

<syntaxhighlight lang="python" line>

  1. 0071 - Reducere

def se_poate_reduca_la_B(A, B):

   i = j = 0
   n = len(A)
   m = len(B)
   while i < n and j < m:
       if A[i] == B[j]:
           i += 1
           j += 1
       else:
           s = A[i]
           i += 1
           while i < n and s < B[j]:
               s += A[i]
               i += 1
           if s != B[j]:
               return 0
           j += 1
   return j == m

def validare(n, A, m, B):

   if not(1 <= n <= 1000) or not(1 <= m <= 1000):
       return False
   if not all(1 <= a <= 10000 for a in A) or not all(1 <= b <= 10000 for b in B):
       return False
   return True

if __name__ == "__main__":

   T = int(input())
   if T <= 0 or T > 10:
       print("Datele nu corespund restricțiilor impuse.")
   else:
       print("Datele sunt introduse corect.")
       for i in range(T):
           n = int(input())
           A = list(map(int, input().split()))
           m = int(input())
           B = list(map(int, input().split()))
           if not validare(n, A, m, B):
               print("Datele nu corespund restricțiilor impuse.")
           else:
               print(se_poate_reduca_la_B(A, B))

</syntaxhighlight>

Explicatie Rezolvare[edit | edit source]

validate_data(a, b): Această funcție primește ca parametri două liste, a și b, reprezentând cele două tablouri. Funcția validează dacă datele introduse respectă restricțiile problemei, adică dacă dimensiunile celor două tablouri sunt între 1 și 1000 și dacă toate elementele tablourilor sunt numere naturale între 1 și 10000. Dacă datele sunt valide, funcția returnează True, în caz contrar returnează False.

reduce(a, b): Această funcție primește ca parametri două liste, a și b, reprezentând cele două tablouri. Funcția verifică dacă tabloul a se poate reduce la tabloul b. În acest scop, parcurge fiecare element al tabloului b și caută în tabloul a o secvență de elemente consecutive aflate pe poziții consecutive în tabloul a, a cărei sumă să fie egală cu elementul curent din tabloul b. Dacă găsește o astfel de secvență, o elimină din tabloul a și trece la următorul element din tabloul b. Dacă nu găsește o astfel de secvență, funcția returnează False. Dacă se parcurge cu succes întregul tablou b și toate elementele sale au fost găsite în tabloul a, funcția returnează True.

main(): Această funcție este funcția principală a programului. Ea citeste datele de intrare din consolă, apoi validează datele folosind funcția validate_data. Dacă datele sunt valide, se parcurg cele t teste și pentru fiecare test se citesc cele două tablouri și se apelează funcția reduce pentru a verifica dacă primul tablou se poate reduce la cel de-al doilea. Rezultatul verificării se afișează în consolă. Dacă datele nu sunt valide, se afișează un mesaj corespunzător.