Создайте последовательность A при помощи следующего генератора: def pseudo_list(): for i...

0 голосов
46 просмотров

Создайте последовательность A при помощи следующего генератора:
def pseudo_list():
for i in range(N):
yield (i*9876+1024)%1000
N = 10**6 + 1
A = pseudo_list())

# Элементы данной последовательности следует перебирать так:
for x in A:
pass # работа с очередным числом x
Найдите «медиану» данного псевдосписка чисел при помощи сортировки подсчётом


Информатика (82 баллов) | 46 просмотров
Дан 1 ответ
0 голосов

Def pseudo_list():
    for i in range(N):
        yield (i*9876+1024)%1000
N = 10**6 + 1
A = pseudo_list()

count = [0] * 1000
for x in A:
    count[x] += 1

x = 0
sum_count = count[0]
while sum_count <= N//2:<br>    x += 1
    sum_count += count[x]    
print(x)
Ответ 496

(131 баллов)