|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
|||
|
|||
Задачи с массивами
Язык совсем не знаю, а без этих программ зачёт не поставят, для меня это может быть сложным, для вас очень лёгким. Помогите, если не сложно
1) Дан текст. Напечатать в алфавитном порядке все глухие согласные буквы, которые не входят только в одно слово; 2)Даны три массива А(7), В(8), С(9) и целое К. Вычислить в каждом массиве сумму элементов, предшествующих элементу с номером К, и произведение элементов, стоящих после него. (Разработать приложение с использованием процедур ввода массива, обработки массива (если можно, то с помощью функции, но без побочных эффектов) и вывода массива (если результат является массивом)) 3)Даны три массива А(7), В(8), С(9) и целое К. Вычислить в каждом массиве сумму элементов, предшествующих элементу с номером К, и произведение элементов, стоящих после него. (Разработать приложение с использованием рекурсивной подпрограммы) |
#2
|
|||
|
|||
1. Лень писать код, там довольно много. Логика такая - разбиваем текст на слова, потом идем по массиву с буквами и проверяем входит ли буква в слово (используем pos, если входит, то уведичиваем счетчик), если счетчик вхождений меньше кол-ва слдов на 1, то печатаем букву.
2. Код:
fnction ArraySum(A : Array Of Integer; K : Integer) : Integer; var I : Integer; begin Result := 0; For I := Low(A) To High(A) Do If I < K Then Result := Result + A[i]; end; function ArrayMult(A : Array Of Integer; K : Integer) : Integer; var I : Integer; begin Result := 1; For I := Low(A) To High(A) Do If I > K Then Result := Result * A[i]; end; 3. Вообще, обрабатывать массив рекурсивной функцией - это бред. Код:
function ArraySum_R(A : Array Of Integer; K, I : Integer) : Integer; begin If I > High(A) Then Result := 0 Else If I < K Then Result := A[i] + ArraySum_R(A,K,I+1) Else Result := ArraySum_R(A,K,I+1) end; function ArrayMult_R(A : Array Of Integer; K, I : Integer) : Integer; begin If I > High(A) Then Result := 1 Else If I > K Then Result := A[i] * ArrayMult_R(A,K,I+1) Else Result := ArrayNult_R(A,K,I+1); end; Код:
const A : Array [1..7] If Integer = (...); B : Array [1..8] If Integer = (...); C : Array [1..9] If Integer = (...); strFmt = 'Array "%s": Sum = %d, Mult = %d'; ... WriteLn(Format(strFmt,['A',ArraySum_R(A,K,Low(A)),ArrayMult_R(A,K,Low(A))]); WriteLn(Format(strFmt,['B',ArraySum_R(A,K,Low(B)),ArrayMult_R(A,K,Low(B))]); WriteLn(Format(strFmt,['C',ArraySum_R(A,K,Low(C)),ArrayMult_R(A,K,Low(C))]); ... ЗЫ. Проверку, что K меньше верхней границы массивов надо сделать при вводе данных. |
Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
NeField (26.05.2022)
|