IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Указатели, рекурсия, помогите, не могу разобраться
сообщение
Сообщение #1





Группа: Пользователи
Сообщений: 4
Пол: Мужской

Репутация: -  0  +


Привет! Помогите мне пожалуйста справиться с заданием
Задание такое:
Объявить массив из 15 указателей на элементы типа real. Используя генератор случайных чисел разместить в динамической памяти 15 вещественных чисел. В подпрограмме-функции найти максимальный элемент и вернуть из функции поиска указатель на найденное значение.

В данном случае не получается организовать функцию, как передать правильно параметры? Вот код без функции:


program ukazat;
const n=15;
var
r : array [1..n] of ^real;
i : integer;
a : Preal;

begin
Randomize;
for i := 1 to n do
begin
New(r[ i ]);
r[ i ]^ := random(n);
writeln (r[ i ]^:2 :0);
end;


for i:=1 to n do
begin
if r[ i ]^ > r[i+1]^ then
begin
a^:=r[ i ]^;
r[ i ]^:=r[i+1]^;
r[i+1]^:=a^;
end;
end;

writeln('Указатель на максимальный элемент: ',a^:2 :0);
for i := 1 to n do Dispose(r[ i ]);
readln;
end.


А это рекурсия - таже трабла не разобраться с функцией :-(

Напишите рекурсивную функцию, которая возвращает среднее из n элементов массива чисел


program recurs;
const n=5;
var
summ,i,j:integer;
mass: array [1..n] of integer;
{---------------------------------------}
function frst(summ:integer):integer;
begin
for i:=1 to n do
begin
frst:=frst(summ)+mass[ i ];
end;
end;
{---------------------------------------}
begin
writeln ('Введите элементы массива');
for i:=1 to n do
readln(mass[ i ]);
frst(summ);
i:=frst(summ);
writeln ('Среднее арифметическое ',n,' чисел= ',i);
readln;
end.


Буду очень рад, хотя бы намеку. Спасибо!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 24.04.2024 1:03
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name