3600 - Numbers Tree

From Bitnami MediaWiki

Cerinţa

Se dă un șir a de n numere naturale nenule strict mai mari decât 1, indexat de la 1. Asupra acestui șir se aplică 3 tipuri de operații:

  • 1 st dr val – toate valorile a[i] cu i din intervalul [st, dr] devin egale cu val;
  • 2 st dr – se cere să se afle câte elemente ale șirului a care au indicii aflați în intervalul [st, dr] sunt numere compuse(un număr natural este compus dacă are cel puțin 3 divizori);
  • 3 st dr – se cere să se afișeze lungimea cele mai lungi secvențe de numere prime alcătuită exclusiv din elemente ale șirului care au indicii aflați în intervalul [st, dr](o secvență a unui șir este alcătuită din elemente aflate poziții consecutive).

Dându-se Q operații, să se raspundă în ordine la cele de tip 2 și 3.

Date de intrare

Fișierul de intrare numbers_tree.in conține pe prima linie numerele n și Q, reprezentând numărul de elemente ale șirului a, respectiv numărul de operații, pe a doua linie n numere naturale separate prin spații reprezentând elementele șirului inițial, iar pe următoarele Q linii sunt descrise operațiile.

Date de ieșire

Fișierul de ieșire numbers_tree.out va conține pe câte o linie răspunsurile la operațiile de tip 2 și 3 în ordinea în care acestea apar în fișierul de intrare.

Restricţii şi precizări

  • 1 ≤ n, Q ≤ 100.000
  • 2 ≤ a[i], val ≤ 1.000.000
  • 1 ≤ st ≤ dr ≤ n

Exemplu

numbers_tree.in
7 7
2 3 4 5 6 7 8
2 1 7
3 1 7
1 2 5 4
2 2 5
3 2 5
1 2 4 3
3 1 6
numbers_tree.out
3
2
4
0
4


Rezolvare

<syntaxhighlight lang="python" line> def read_input(filename):

   with open(filename, 'r') as f:
       n, Q = map(int, f.readline().split())
       a = list(map(int, f.readline().split()))
       operations = [list(map(int, line.split())) for line in f.readlines()]
   return n, a, operations

def is_prime(num):

   if num < 2:
       return False
   for i in range(2, int(num ** 0.5) + 1):
       if num % i == 0:
           return False
   return True

def apply_operation_2(a, st, dr):

   count_composite = 0
   for i in range(st - 1, dr):
       if a[i] > 1 and not is_prime(a[i]):
           count_composite += 1
   return count_composite

def apply_operation_3(a, st, dr):

   max_prime_sequence = 0
   current_prime_sequence = 0
   for i in range(st - 1, dr):
       if is_prime(a[i]):
           current_prime_sequence += 1
           max_prime_sequence = max(max_prime_sequence, current_prime_sequence)
       else:
           current_prime_sequence = 0
   return max_prime_sequence

def process_operations(n, a, operations):

   result = []
   for op in operations:
       if op[0] == 2:
           count_composite = apply_operation_2(a, op[1], op[2])
           result.append(count_composite)
       elif op[0] == 3:
           max_prime_sequence = apply_operation_3(a, op[1], op[2])
           result.append(max_prime_sequence)
   return result

def write_output(filename, result):

   with open(filename, 'w') as f:
       for res in result:
           f.write(str(res) + '\n')

def main():

   input_file = "numbers_tree.in"
   output_file = "numbers_tree.out"
   n, a, operations = read_input(input_file)
   result = process_operations(n, a, operations)
   write_output(output_file, result)

if __name__ == "__main__":

   main()

</syntaxhighlight>