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

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

10.03.2019, 13:08. Показов 18520. Ответов 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
 Аватар для Рыжий Лис
5973 / 3735 / 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
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru