!!!!!Дан массив сопротивлений, хранящихся ** складе, упорядоченных по возрастанию....

0 голосов
12 просмотров

!!!!!
Дан массив сопротивлений, хранящихся на складе, упорядоченных по возрастанию.
Программа получает на вход массив неотрицательных вещественных значений сопротивлений, упорядоченный по возрастанию содержащий не менее двух элементов. Пользователь задаёт значение для поиска в виде номинала сопротивления. Программа должна вывести номинальные значения, близкие к введенному значению и индекс элемента в массиве. Если сопротивление отсутствует в массиве, производится поиск наиболее близких двух значений, меньшего и большего относительно заданного. Если сопротивление точно равно – выводится одно значение. Если введенное значение выходит за границы элементов массива – выводится также одно значение, соответствующее его границе как показано на рисунке. При выходе за границы дополнительно вывести сообщения «Сопротивление слишком большое, на складе отсутствует» «Сопротивление слишком мало, на складе отсутствует». Вывести номера ячеек, соответствующе значению индекса плюс единица.


Информатика (12 баллов) | 12 просмотров
Дан 1 ответ
0 голосов

На каком языке программу писать, не сказано, будет только алгоритм.
1) Начало
2) Ввод массива сопротивлений R(n), упорядоченного по возрастанию
3) Ввод нужного сопротивления R0.
4) Флаг признака "Сопротивление найдено" F = 0
5) Если R0 < R(1), то
5.1) Вывод R(1), номера 1 и сообщения "Сопротивление слишком мало, на складе отсутствует"
5.2) Флаг признака "Сопротивление найдено" F = 1
5.3) Конец Если
6) Если R0 > R(n), то
6.1) Вывод R(n), номера n и сообщения "Сопротивление слишком большое, на складе отсутствует"
6.2) Флаг признака "Сопротивление найдено" F = 1
6.3) Конец Если
7) Если R0 >= R(1) и R0 <= R(n), то<br>7.1) Если R0 = R(1), то
7.1.1) Вывод R(1) и номера 1
7.1.2) Флаг признака "Сопротивление найдено" F = 1
7.1.3) Конец Если
7.2) Если Флаг признака F = 1, то Конец программы
7.3) Цикл по i от 2 до n
7.3.1) Если R0 = R(i), то Вывод R(i) и номера i
7.3.2) Иначе, Если (R0 > R(i-1)) и (R0 < R(i)), то
Вывод сопротивлений R(i-1) и R(i) и номеров (i-1) и i
7.3.3) Конец Если
7.4) Конец Цикла по i
8) Конец программы

(320k баллов)