Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/88: Рейтинг темы: голосов - 88, средняя оценка - 4.65
2 / 2 / 0
Регистрация: 25.03.2018
Сообщений: 91

Найти медиану массива

10.03.2019, 13:08. Показов 18228. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Объясните пожалуйста!

Напишите программу, которая ищет медиану массива – элемент, делящий его на две равные части: в одной находятся элементы, которые не меньше медианы, в другой -– не больше медианы.

Входные данные
Первая строка содержит размер массива N . Во второй строке через пробел задаются N чисел – элементы массива. Гарантируется, что 0 < N ≤ 100000 и N – нечётное число.

Выходные данные
Программа должна вывести одно число – медиану массива.

Примеры
входные данные
5
3 1 4 2 5
выходные данные
3
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.03.2019, 13:08
Ответы с готовыми решениями:

Найти медиану в списке
Как найти медиану в списке? пытался использовать from statistics import median но пишет что: list indices must be integers or...

Как найти медиану неотсортированного массива (без использования дополнительного массива)
как найти медиану неотсортированного массива, при этом не используя дополнительных массивов и не сортируя его.

Найти медиану массива
Реализовать функцию median, которое находится в середине массива, если его упорядочить по возрастанию, то есть такое число, что половина из...

9
 Аватар для m0nte-cr1st0
1043 / 578 / 242
Регистрация: 15.01.2019
Сообщений: 2,178
Записей в блоге: 1
10.03.2019, 13:19
а сам?
0
2 / 2 / 0
Регистрация: 25.03.2018
Сообщений: 91
10.03.2019, 13:21  [ТС]
m0nte-cr1st0, сам пробовал, поэтому тут прошу
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5972 / 3734 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
10.03.2019, 15:08
И где код, что вы пробовали?

Python
1
2
3
4
5
6
ls = [3, 1, 4, 2, 5]
 
ls.sort()
n = len(ls)
assert n % 2 == 1
print(ls[n // 2])
0
 Аватар для m0nte-cr1st0
1043 / 578 / 242
Регистрация: 15.01.2019
Сообщений: 2,178
Записей в блоге: 1
10.03.2019, 16:51
Цитата Сообщение от Pavlin235 Посмотреть сообщение
сам пробовал, поэтому тут прошу
код скинь, что пробовал?
0
Эксперт Python
 Аватар для dondublon
4651 / 2071 / 366
Регистрация: 17.03.2012
Сообщений: 10,180
Записей в блоге: 6
12.03.2019, 12:40
Pavlin235, в numpy готовая функция есть, median кажись.
0
Эксперт Python
1356 / 653 / 207
Регистрация: 23.03.2014
Сообщений: 3,057
13.03.2019, 14:21
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import random
def medfinder(n):
    mlist = [random.randint(-10, 10) for i in range(n)]
    print(mlist)
    strlst=sorted(mlist)
    print(strlst)
    lstlen=len(mlist)
    index=(lstlen-1)//2
    if lstlen%2==0:
        res=strlst
        print(res)
        return res
    else:
        res=(strlst[index]+strlst[index+1])/2.0
        print(res)
        return res
if __name__ == '__main__':
    n=int(input())
    medfinder(n)
Добавлено через 7 минут
Чуть более точно:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import random
def medfinder(n):
    mlist = [random.randint(-10, 10) for i in range(n)]
    print(mlist)
    strlst=sorted(mlist)
    print(strlst)
    lstlen=len(mlist)
    index=(lstlen-1)//2
    if lstlen%2==0:
        res=strlst[index]
        print(res)
        return res
    else:
        res=(strlst[index]+strlst[index+1])/2.0
        print(res)
        return res
if __name__ == '__main__':
    n=int(input())
    medfinder(n)
Добавлено через 2 минуты
Уважаемые администраторы, почините возможность правки кода, а то флуд разводится не произвольно.
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
13.03.2019, 14:34
Все уже встроено - чего там изобретать:
Python
1
2
import statistics
statistics.median(data)

Не по теме:

Цитата Сообщение от Dax Посмотреть сообщение
почините возможность правки кода,
Это не чинится модераторами - возможность безлимитной (после 5 минут) личной правки своих постов здесь давно отменили.
Отредактировать можно только через обращение к модератору - для этого нужно "пожаловаться" на свой пост (красный треугольник).

0
 Аватар для m0nte-cr1st0
1043 / 578 / 242
Регистрация: 15.01.2019
Сообщений: 2,178
Записей в блоге: 1
13.03.2019, 14:50
Garry Galler,

Не по теме:

было бы неплохо, если бы определённая группа пользователей (не только модераторы/админы) могла править сообщения (может, даже и чужие), типа как на стэковерфлоу

0
Эксперт Python
1356 / 653 / 207
Регистрация: 23.03.2014
Сообщений: 3,057
13.03.2019, 15:14
Garry Galler, спасибо, разобрался.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.03.2019, 15:14
Помогаю со студенческими работами здесь

Найти медиану массива
include&lt;iostream&gt; #include &lt;cstdlib&gt; #include &lt;time.h&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;RUS&quot;); ...

Найти медиану массива
Найти медиану массива - значение и номер элемента, который равен или ближе всего к среднему значению для массива.

Найти медиану массива
нужно найти медиану массива(центр массива),если в массиве нечетное кол-во элементов то это будет центральное число,а если четное то берутся...

Найти медиану массива
&quot;Повышенной сложности: найти медиану массива – элемент, разделяющий массив на две наиболее близких по сумме части&quot; Это как? Т.е...

Найти медиану массива
Напишите программу, которая ищет медиану массива – элемент, делящий его на две равные части: в одной находятся элементы, Есть далеко...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru