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

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

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

> Указатели, рекурсия, помогите, не могу разобраться
aspi
сообщение 23.05.2008 20:12
Сообщение #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 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
aspi
сообщение 9.06.2008 19:24
Сообщение #2





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

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


Вот мои попытки над рекурсией, с процедурами и функциями совсем туго. mega_chok.gif

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



А вот попытки с указателем:


program ukazat;
const n=15;
type
Preal=^real;

var
r : array [1..n] of ^real;
i : integer;
a : Preal;
z : Preal;


function poisk (var b:array of real):Preal;
begin
for i:=low(b) to high(b) do

begin
if r[i]^ > r[i+1]^ then
begin
a:=r[i]^;
end;
poisk:=@a;
exit
end;

end;

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

poisk(?);

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




 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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


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

 



- Текстовая версия 29.07.2025 11:17
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"