3239 - chain

From Bitnami MediaWiki

Enunt

Se dă o secvență de N numere întregi a1, a2, …, aN. Pentru fiecare element ak (k = 1, 2, ...,n) vom determina primul element mai mare decât ak, dacă există. Îl notăm cu ak1. Apoi, pentru ak1 facem același lucru și elementul găsit îl notăm cu ak2, și așa mai departe până ieșim în afara șirului. Se formează secvența ak1, ak2, …, pe care o numim chain începând cu poziția k.

Cerinta

Scrieți un program care, pentru orice poziție k afișează lungimea secvenței chain corespunzătoare.

Date de intrare

Pe prima linie a intrării standard se dă valoarea N. Pe a doua linie se dau elementele șirului, separate prin spații.

Date de iesire

Pe o linie a ieșirii standard, programul va scrie șirul valorilor ce reprezintă lungimile secvențelor chain corespunzătoare elementelor șirului de intrare. Fiecare două numere consecutive trebuie separate printr-un singur spațiu.

Restrictii si precizari

  • 0 < N < 500.000
  • 0 < ai < 1.000.000, pentru fiecare i = 1..N.

Exemplul 1

intrare
11
3 2 4 2 11 2 7 5 8 10 6
iesire
Datele introduse corespund restrictiilor impuse.
2 2 1 1 0 3 2 2 1 0 0

Exemplul 2

intrare
2
5 6 8 1 3 9 5 7 9 3 5
iesire
Datele de intrare nu corespund restrictiilor impuse.

Rezolvare

<syntaxhighlight lang="python3" line="1">

  1. 3239 - chain

def find_chain_length(sequence, k):

   n = len(sequence)
   chain_length = 0
   current_position = k - 1
   while current_position < n:
       current_element = sequence[current_position]
       next_position = current_position + 1
       while next_position < n and sequence[next_position] <= current_element:
           next_position += 1
       if next_position < n:
           chain_length += 1
           current_position = next_position
       else:
           break
   return chain_length

</syntaxhighlight>