Задача для паскаля. Во входном файле имеется массив из 10 целых чисел.
Задачка для паскаля. Во входном файле имеется массив из 10 целых чисел. Первые 9 частей упорядочены. В выходной файл вставить 10-й элемент так, чтобы все элементы массива были упорядочены.
Задать свой вопрос1 ответ
Лариса
Const
n = 10;
var
i, k, j: integer;
a: array[1..n] of integer;
begin
Write('Введите через пробел девять целых чисел в порядке возрастания: ');
for i := 1 to n - 1 do Read(a[i]);
Write('Введите целое число для вставки: '); Read(k);
Определим позицию для вставки
i := 1;
while (k gt; a[i]) and (i lt; n) do i := i + 1;
Выполним сдвиг бОльших частей вправо
for j := n - 1 downto i do a[j + 1] := a[j];
Осуществим вставку
a[i] := k;
Контрольный вывод
Writeln('Результирующий массив');
for i := 1 to n do Write(a[i], ' ')
end.
Тестовые решения:
Введите через пробел девять целых чисел в порядке возрастания: 3 6 8 10 14 15 17 19 24
Введите целое число для вставки: 25
Результирующий массив
3 6 8 10 14 15 17 19 24 25
Введите через пробел девять целых чисел в порядке возрастания: 3 6 8 10 14 15 17 19 24
Введите целое число для вставки: 0
Результирующий массив
0 3 6 8 10 14 15 17 19 24
Введите через пробел девять целых чисел в порядке возрастания: 3 6 8 10 14 15 17 19 24
Введите целое число для вставки: 13
Результирующий массив
3 6 8 10 13 14 15 17 19 24
n = 10;
var
i, k, j: integer;
a: array[1..n] of integer;
begin
Write('Введите через пробел девять целых чисел в порядке возрастания: ');
for i := 1 to n - 1 do Read(a[i]);
Write('Введите целое число для вставки: '); Read(k);
Определим позицию для вставки
i := 1;
while (k gt; a[i]) and (i lt; n) do i := i + 1;
Выполним сдвиг бОльших частей вправо
for j := n - 1 downto i do a[j + 1] := a[j];
Осуществим вставку
a[i] := k;
Контрольный вывод
Writeln('Результирующий массив');
for i := 1 to n do Write(a[i], ' ')
end.
Тестовые решения:
Введите через пробел девять целых чисел в порядке возрастания: 3 6 8 10 14 15 17 19 24
Введите целое число для вставки: 25
Результирующий массив
3 6 8 10 14 15 17 19 24 25
Введите через пробел девять целых чисел в порядке возрастания: 3 6 8 10 14 15 17 19 24
Введите целое число для вставки: 0
Результирующий массив
0 3 6 8 10 14 15 17 19 24
Введите через пробел девять целых чисел в порядке возрастания: 3 6 8 10 14 15 17 19 24
Введите целое число для вставки: 13
Результирующий массив
3 6 8 10 13 14 15 17 19 24
Степа Фруентов
А если с привязкой к файлу?
Толян Мадюков
Тогда эти данные надобно поместить в файл, к примеру, в текстовый (var f:file of Text), вбить их туда по одному на строке, а потом, как обычно: Assign(f,'inpet.txt'); Reset(f) и в теле цикла заместо Read(a[i]) записать Readln(f,a[i]); Я сделал без файла, чтоб показать все три вероятные варианта вставки. да после чтения файла, за циклом, его можно закрыть оператором Close(f);
, оставишь ответ?
Похожие вопросы
-
Вопросы ответы
Новое
NEW
Статьи
Информатика
Статьи
Последние вопросы
Игорь 14 лет назад был на 8 лет моложе, чем его
Математика.
Два тела массами m1 и m2 находящие на расстоянии R друг
Физика.
В сосуде 4целых одна пятая литр воды что бы заполнить сосуд
Математика.
Двум малярам Диме И Олегу поручили выкрасить фасад дома они разделили
Разные вопросы.
найти порядковый номер 41Э если в ядре 20 нейтронов
Разные вопросы.
в ряду натуральных чисел 3, 8, 10, 24, … 18 одно
Математика.
Предприятие по производству с/хоз продукции на производство затратило 3527000 руб Валовый
Разные вопросы.
Математика, задано на каникулы. ВАРИАНТ 1004
НОМЕР 1,2,3,4,5,6,7,8.
Математика.
Имеются три конденсатора емкостью С1=1мкФ, С2=2мкФ и С3=3мкФ. Какую наименьшую емкость
Физика.
Из точки м выходят 3 луча MP MN и MK причём
Геометрия.
Облако тегов