(брать версию для python 3.5, версию для x64, если у вас 64-х битная ось)
Во-вторых, рекомендуется переходить на IDE PyCharm, который имеет достаточно много фич, которые нам будут удобны.
Основные — это большое количество подсказок в процессе написания кода.
Основные hot key:
Ctrl+Alt+E — выполнить выделенный код в консоли
Shift+Ctrl+F10 — запустить текущий скрипт целиком в отдельном процессе
Ссылки по теме:
Если вы знаете английски, то лучше всего подойдёт оригинальный tutorial: https://docs.scipy.org/doc/num[..]user/quickstart.html
Иначе можно начать со странички https://pythonworld.ru/numpy/1.html
Задачи
01. Массив нулейНа вход даётся число n. Выведите массив нулей n на n
02. Числа на диагонали
На вход даётся число n. Выведите массив размера n на n,
в котором по диагонали идут числа 0 до n-1, а остальные числа равны 0
в котором по диагонали идут числа 0 до n-1, а остальные числа равны 0
03. Числа в нулевой строке
На вход даётся число n. Выведите массив размера n на n,
в котором в первой строчке идут числа от 0 до n-1, а остальные числа равны 0
в котором в первой строчке идут числа от 0 до n-1, а остальные числа равны 0
04. Сбитый прицел
На вход даётся числа n, r, c. Выведите массив размера n на n, в котором
в строке r и столбце c стоят 1, а остальные числа равны 0
в строке r и столбце c стоят 1, а остальные числа равны 0
05. Почётные единицы
На вход даётся число n. Выведите массив размера n на n,
в котором в чётных строчках стоят 1, а в нечётных
нули
в котором в чётных строчках стоят 1, а в нечётных
нули
06. Решето
На вход даётся числа n, r, c. Выведите массив размера n на n, в котором
в котором в каждой R-ой строчке и в каждом C-ом столбце стоят 1
в котором в каждой R-ой строчке и в каждом C-ом столбце стоят 1
07. Шахматы единиц
На вход даётся число n. Выведите массив размера n на n,
имеющий вид шахматной доски.
имеющий вид шахматной доски.
08. Разлиновка
На вход даётся число n. В следующей строке идёт несколько чисел. Выведите массив размера n на n,
в котором в строках с перечисленными выше индексами стоят 1.
в котором в строках с перечисленными выше индексами стоят 1.
09. Порядок индексов
Даны числа w и h
ширина и высота картинки в пикселях.
Создайте подходящий массив, в котором можно хранить трёхцветную картинку данной ширины и высоты.
При этом данные в памяти должны храниться так, чтобы сначала шли три цвета одного пикселя,
затем цвета следующего пикселя в этой же строчке или первый пиксель из следующей строчки.
ширина и высота картинки в пикселях.
Создайте подходящий массив, в котором можно хранить трёхцветную картинку данной ширины и высоты.
При этом данные в памяти должны храниться так, чтобы сначала шли три цвета одного пикселя,
затем цвета следующего пикселя в этой же строчке или первый пиксель из следующей строчки.
10. Картинки
Скачайте картинки: и . Прочитайте их в numpy-массив при помощи команд вида
Сохранять изменённые картинки можно при помощи команды
Извлеките из цветной картинки только зелёный слой и сохраните в отдельный файл.
from skimage import io
img = io.imread('30x60g.png')
Сохранять изменённые картинки можно при помощи команды
from skimage import io
io.imsave('res.png', img)
Извлеките из цветной картинки только зелёный слой и сохраните в отдельный файл.
11. Состыковка
Состыкуйте две ч/б картинки так, чтобы получилась картинка 60х60, и 30х120. Сохраните их в отдельные файлы.
Сделайте то же самое с цветными картинками.
Сделайте то же самое с цветными картинками.
12. Вставка
Добавьте в ч/б картинку по центру белую вертикальную полосу шириной в 10 пикселей. Сохраните картинку в отдельный файл.
Добавьте ещё и горизонтальную серую полосу.
Теперь в цветную картинку добавьте зелёную вертикальную полосу и красную горизонтальную (каждую по центру, шириной 10 пикселей)
Добавьте ещё и горизонтальную серую полосу.
Теперь в цветную картинку добавьте зелёную вертикальную полосу и красную горизонтальную (каждую по центру, шириной 10 пикселей)
13. Удаление
Удалите из картинок центральную полосу шириной в 10 пикселей (всё аналогично 12-й задаче).
14. Отрезок
Создайте белую картинку 100х100 пикселей.
Проведите на ней отрезок из точки (x1,y1) в точку (x2,y2).
Сохраните картинку в файл (или нагуглите, как её показать прямо из программы).
Проведите на ней отрезок из точки (x1,y1) в точку (x2,y2).
Сохраните картинку в файл (или нагуглите, как её показать прямо из программы).
15. Случайное подмножество строк
Дан массив размера HxW и число k.
Отберите случайные k строк из массива и сформируйте из них массив размера kxW.
Отберите случайные k строк из массива и сформируйте из них массив размера kxW.
16. Перемешать строки
Перемешайте случайным образом строки прямоугольного массива
17. Индекс в массиве
Дан массив размерности (6,7,8). Каков индекс (x,y,z) сотого элемента?
18. Поменять знак
Дан массив, поменять знак у элементов, значения которых между 3 и 8
19. Заменить все максимумы
Дан массив. Заменить все значения, равные максимальному, на -1.
20. Ближайшее
Найти ближайшее к заданному значению число в заданном массиве
21. Сортировка
Отсортировать данный линейный массив
22. argsort
Для каждого элемента данного линейного массива найдите позицию, на которую он попадёт, если массив отсортировать
23. argsort – 2
Даны три линейных массива длины N. В первом массиве хранятся стоимости брусков, во втором – длины, а в третьем – массы. Отсортируйте массивы так, чтобы данные по брускам шли в порядке возрастания стоимости.
24. Нормировка
Дан массив действительных чисел. Отнормируйте (X -> aX+b) его так, чтобы все числа лежали на отрезке [0,1] и значения 0 и 1 принимались. Гарантируется, что в массиве есть хотя бы два различных числа.