![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() ![]() |
![]() |
aspi |
![]()
Сообщение
#1
|
Группа: Пользователи Сообщений: 4 Пол: Мужской Репутация: ![]() ![]() ![]() |
Привет! Помогите мне пожалуйста справиться с заданием
Задание такое: Объявить массив из 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.
Буду очень рад, хотя бы намеку. Спасибо! |
klem4 |
![]()
Сообщение
#2
|
![]() Perl. Just code it! ![]() ![]() ![]() ![]() ![]() ![]() Группа: Модераторы Сообщений: 4 100 Пол: Мужской Реальное имя: Андрей Репутация: ![]() ![]() ![]() |
во-первых:
Цитата for i := 1 to n do begin New(r[i]); // <----- во-вторых зачем сортируешь массив ? Максимум можно найти намного проще:
maxi := 1;
for i := 2 to n do
if r[i]^ > r[maxi]^ then
maxi := i;
// теперь максимальный элемент r[maxi]^
Сообщение отредактировано: klem4 - 23.05.2008 20:32 -------------------- perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
|
aspi |
![]()
Сообщение
#3
|
Группа: Пользователи Сообщений: 4 Пол: Мужской Репутация: ![]() ![]() ![]() |
Спасибо. А как оформить процедуру, пытаюсь - всё зацикливается...
![]() |
volvo |
![]()
Сообщение
#4
|
Гость ![]() |
Ты бы показал, как пытался сделать...
|
aspi |
![]()
Сообщение
#5
|
Группа: Пользователи Сообщений: 4 Пол: Мужской Репутация: ![]() ![]() ![]() |
Вот мои попытки над рекурсией, с процедурами и функциями совсем туго.
![]()
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]^
0);
end;
poisk(?);
writeln('Указатель на максимальный элемент: ',a^
0);
for i := 1 to n do Dispose(r[i]);
readln;
end.
|
volvo |
![]()
Сообщение
#6
|
Гость ![]() |
Смотри:
program ukazat;
const
n = 15;
type
preal = ^real;
function poisk (var b:array of preal):Preal; { <--- Первая ошибка - нужно "array of PREAL" }
var i, max_i: integer;
begin
max_i := low(b);
for i := low(b) to high(b) do
if b[i]^ > b[max_i]^ then max_i := i; { обычный поиск максимума }
poisk:=b[max_i];
end;
var
r: array [1 .. n] of preal;
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;
a := poisk(r); { <--- Ну, и вызов ... }
writeln('Максимальный элемент: ',a^: 2: 0);
for i := 1 to n do Dispose(r[i]);
readln;
end.
Это имелось в виду? |
aspi |
![]()
Сообщение
#7
|
Группа: Пользователи Сообщений: 4 Пол: Мужской Репутация: ![]() ![]() ![]() |
Цитата Это имелось в виду? Да! Спасибо всё работает! не допечатал 2 слова.... ![]() С рекурсией сейчас попробую разобраться, там в процедуре summ:=summa-5; вместо -5 надо поставить /n, но пишет о несовпадении типов...? |
volvo |
![]()
Сообщение
#8
|
Гость ![]() |
Цитата пишет о несовпадении типов Правильно делает: деление всегда возвращает результат вещественного типа, а попытка присвоить его целочисленной переменной карается сообщением об ошибке... Вот так будет лучше:
{---------------------------------------}
function frst(var a: array of integer; i: integer): real;
begin
if pred(i) > high(a) then frst := 0
else frst := frst(a, i + 1) + a[i - 1] / n;
end;
{---------------------------------------}
var summa: real; { <--- Внимательнее с типами !!! }
{ Вызывать - так: }
summa := frst(mass, 1);
|
![]() ![]() |
![]() |
Текстовая версия | 27.07.2025 10:07 |