Форум по Delphi программированию



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ] > Код на шару!
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 25.05.2022, 01:52
NeField NeField вне форума
Прохожий
 
Регистрация: 24.05.2022
Сообщения: 3
Версия Delphi: Delphi 7
Репутация: 10
Печаль Задачи с массивами

Язык совсем не знаю, а без этих программ зачёт не поставят, для меня это может быть сложным, для вас очень лёгким. Помогите, если не сложно

1) Дан текст. Напечатать в алфавитном порядке все глухие согласные буквы, которые не входят только в одно слово;

2)Даны три массива А(7), В(8), С(9) и целое К. Вычислить в каждом массиве сумму элементов, предшествующих элементу с номером К, и произведение элементов, стоящих после него.
(Разработать приложение с использованием процедур ввода массива, обработки массива (если можно, то с помощью функции, но без побочных эффектов) и вывода массива (если результат является массивом))

3)Даны три массива А(7), В(8), С(9) и целое К. Вычислить в каждом массиве сумму элементов, предшествующих элементу с номером К, и произведение элементов, стоящих после него.
(Разработать приложение с использованием рекурсивной подпрограммы)
Ответить с цитированием
  #2  
Старый 26.05.2022, 18:27
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 7,799
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

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)
Ответ



Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра
Комбинированный вид Комбинированный вид

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 07:13.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2021

ВКонтакте   Facebook   Twitter   Ссылка на Telegram