Задание 2 – Работа с одномерными массивами числовых данных
Описание задания и критерии оценки:
Вам необходимо выбрать и выполнить одно из предложенных ниже заданий. Критерии оценки: выполнение каждого из следующих условий увеличивает итоговую сумму баллов за задание на указанную величину:
Программа компилируется, запускается и выводит правильный результат. Вы устно комментируете код, отвечаете на все заданные вопросы – 3 балла;
В программе организован понятный для пользователя ввод/вывод (при запросе исходных данных соответствующий запрос должен выводиться на экран с соблюдением правил написания).
Вводимые данные проверяются на корректность (например: если требуется ввести неубывающую последовательность чисел, то при невыполнении этого требования пользователю выводится поясняющее сообщение и предоставляется возможность повторного ввода и т.п.) – 1 балл;
Задания:
Дан массив из 30 элементов. Найти пять соседних элементов, сумма значений которых максимальна.
Дан массив целых чисел. Все элементы, оканчивающиеся цифрой 4, уменьшить вдвое.
Найти число пар соседних элементов массива, являющихся четными числами.
Дан массив. Определить количество элементов, больших суммы всех элементов массива, и напечатать их номера.
Найти элемент, наиболее близкий к среднему значению всех элементов массива.
По заданным вещественным числам a0, a1, …a10 (а - массив), t вычислить значение многочлена a10x10 + a9x9 + … + a1x1 + a0 и его производной в точке t.
Определить, имеются ли в массиве одинаковые элементы.
В массиве числа образуют неубывающую последовательность. Несколько элементов, идущих подряд, равны между собой. Найти количество таких элементов.
Даны два массива. Найти наименьшее среди тех чисел первого массива, которые не входят во второй массив (считая, что хотя бы одно такое число есть).
В массиве числа образуют неубывающую последовательность. Найти количество различных чисел в массиве.
Дан массив. Определить номера минимального элемента массива и элемента, являющегося минимальным без учета этого элемента.
Изменить знак у максимального по модулю элемента массива.
Переменной t присвоить значение 1 или 0 (истина или ложь) в зависимости от того, есть ли среди элементов массива число, являющееся степенью двойки.
Удалить из массива первый отрицательный элемент (если отрицательные элементы есть). Под удалением элемента понимается исключение этого элемента из массива путем смещения всех следующих за ним элементов влево на 1 позицию и присваивание последнему элементу массива значения 0.
Рассматривая массив как последовательность цифр десятичной записи некоторого неотрицательного целого числа, получить само это число. (Например, массив {1,2,3} представляет число 123).
Вставить заданное число в массив целых чисел перед последним четным элементом (если четные элементы есть). Под вставкой числа n в массив после k-го элемента понимается смещение всех элементов, начиная с (k+1)-го вправо на 1 позицию, и присваивание (k+1)-му элементу массива значения n.
Если в массиве есть хотя бы одна пара соседних неотрицательных элементов, то напечатать все элементы, следующие за элементами первой из таких пар.
Дан массив. Переписать его положительные элементы во второй массив, а остальные – в третий. Во втором и третьем массивах значения элементов первого массива должны быть записаны подряд с начала массива.
Элементы массива циклически сдвинуть на две позиции влево.
Вычислить y = x1 + x1x2 + x1x2x3 + … + x1x2…xm, где m – либо номер первого отрицательного элемента массива x, либо номер последнего элемента, если в массиве x нет отрицательных элементов.
Найти сумму элементов массива, расположенных между максимальным и минимальным элементами (включительно).
Разрешается сдавать не больше двух задач на дополнительные баллы. Выбранные задачи можно сдать только после того, как сдана обязательная задача.
Задачи на дополнительные баллы по теме «Работа с одномерными массивами числовых данных» (5 баллов):
Даны два массива. Элементы каждого из массивов упорядочены по неубыванию. Объединить элементы этих двух массивов в третий массив так, чтобы они снова оказались упорядоченными по неубыванию.
Упорядочить массив по неубыванию, используя алгоритм сортировки выбором: отыскивается максимальный элемент и переносится в конец массива; затем этот метод применяется ко всем элементам, кроме последнего, который уже находится на своем месте, и т.д.
Для арифметических операций с большими числами, которые не могут быть представлены в памяти компьютера, используется следующий прием. Каждая цифра таких чисел записывается в отдельный элемент массива, и необходимые операции проводятся с элементами массива цифр. Написать программу выполняющую сложение 20-значных чисел.
Подсчитать количество «счастливых» шестизначных автобусных билетов, т.е. таких, в номерах которых сумма трех первых цифр равна сумме трех последних. (Воспользоваться тем, что число «счастливых» билетов равно s_0^2+s_1^2+⋯+s_27^2, где s_n – количество чисел от 0 до 999, сумма цифр которых равна n).
Элементы массива x упорядочены по возрастанию. Требуется присвоить переменной k номер элемента массива, равного числу y, или -1, если такого элемента нет. Использовать метод двоичного (бинарного) поиска: сравнить y со средним элементом массива (или элементом около середины); если эти числа равны, поиск завершается, если же y меньше среднего элемента, то y надо искать в левой половине массива, а иначе – в правой; к выбранной половине применяется этот же алгоритм.
Удалить из массива все повторяющиеся элементы, оставив их первые вхождения, то есть в массиве должны остаться только различные элементы.
Работа с одномерными массивами числовых данных
Контрольная работа по предмету «Алгебра»